我可以更改背景颜色红色,蓝色以及绿色,
但是,当我单击“重置”按钮时,Chrome(浏览器)出现错误:
btnReset不是函数,
当我单击“重置”按钮时,如何使所有div空白?
function btnRed() {
document.getElementById("Div1").style.backgroundColor="Red";
}
function btnGreen() {
document.getElementById("Div2").style.backgroundColor="Green";
}
function btnBlue() {
document.getElementById("Div3").style.backgroundColor="Blue";
}
function btnReset() {
document.getElementById("Div1").style.backgroundColor="Black";
document.getElementById("Div2").style.backgroundColor="white";
document.getElementById("Div3").style.backgroundColor="white";
}
#Div1
{
z-index: -2;
border: 1px solid black;
height: 300px;
width: 400px;
}
#Div2
{
z-index: -1;
border: 1px solid black;
width: 300px;
height: 200px;
margin: 50px 0 0 50px;
}
#Div3
{
border: 1px solid black;
width: 200px;
height: 150px;
margin: 23px 0 0 47px;
}
#DivBtn
{
margin-top: 30px;
}
<div id="Div1">
<div id="Div2">
<div id="Div3">
</div>
</div>
</div>
<div id="DivBtn"> <input type="button" id="btnR" value="Red" onclick="btnRed();">
<input type="button" id="btnG" value="Green" onclick="btnGreen();">
<input type="button" id="btnB" value="Blue" onclick="btnBlue();">
<input type="button" id="btnReset" value="Reset" onclick="btnReset()">
</div>
最佳答案
在html标记上使用id
时要小心,因为它会使用id
进行自动var声明。因此,您要使用指向btnReset
的btnReset
覆盖<input>
函数。
解决方案1:更改id="btnReset"
或function btnReset()
名称!
解决方案2:将<script>
移动到文档的末尾(恰好在</body>
end标记之前,因此您的函数将覆盖自动声明的var。
附加信息:http://www.2ality.com/2012/08/ids-are-global.html