这个JS代码 为什么加到另一个div的id里不起作用呢?

有两个div,id分别为“a1”和“a2”,我想要两个div的id都使用这段JS改变li的背景颜色,但是不知道为什么,复制多一份JS,getElementById()改为... 有两个div, id分别为“a1”和“a2”, 我想要两个div的id都使用这段JS改变li的背景颜色,
但是不知道为什么,复制多一份JS,getElementById()改为a2,a2起作用了,但a1的却不起作用了,
<script type="text/javascript">
window.onload = function(){
var divs = document.getElementById("a1").getElementsByTagName("li");
var len = divs.length;
for(var i=0;i<len;i++){
divs[i].onclick = function(){
for(var j=0;j<len;j++){
divs[j].style.backgroundColor = "";
}
this.style.backgroundColor = "rgb(65, 117, 252)";
};
}
};
</script>

请问是哪里出错了吗?
展开
 我来答
yugi111
2015-01-20 · TA获得超过8.1万个赞
知道大有可为答主
回答量:5.1万
采纳率:70%
帮助的人:1.3亿
展开全部
<!DOCTYPE HTML>
<html>
<head>
<meta charset="UTF-8" />
<title>last.html</title>
<style>
</style>
<script type="text/javascript">
var changeColor = function (id)
    {
    var div = document.getElementById (id);
    div.index = -1;
    var lis = div.getElementsByTagName ("li");
    var len = lis.length;
    for ( var i = 0; i < len; i++)
    {
    lis[i].index = i;
    lis[i].onclick = function ()
    {
    if (div.index != -1)
    {
    lis[div.index].style.backgroundColor = "";
    }
    this.style.backgroundColor = "rgb(65, 117, 252)";
    div.index = this.index;
    };
    }
    }
    
    onload = function ()
    {
    changeColor ("a1");
    changeColor ("a2");
    }
</script>
</head>
<body>
<div id="a1">
div1
<ul>
<li>dddddddddd</li>
<li>dddddddddd</li>
<li>dddddddddd</li>
</ul>
</div>
<div id="a2">
div2
<ul>
<li>ssssssssssss</li>
<li>ssssssssssss</li>
<li>ssssssssssss</li>
</ul>
</div>
</body>
</html>
bfdnyj
2015-03-03 · TA获得超过469个赞
知道小有建树答主
回答量:217
采纳率:100%
帮助的人:135万
展开全部

window.onload = function(){……} 只能用一次,再次使用就会把上一次设定的处理函数顶掉。

<script type="text/javascript">

window.onload = function(){

var divs1 = document.getElementById("a1").getElementsByTagName("li");

var len1 = divs1.length;

for(var i=0;i<len1;i++){

divs[i].onclick = function(){

for(var j=0;j<len1;j++){

divs1[j].style.backgroundColor = "";

}

this.style.backgroundColor = "rgb(65, 117, 252)";

};

}

var divs2 = document.getElementById("a2").getElementsByTagName("li");

var len2 = divs2.length;

for(var i=0;i<len2;i++){

divs[i].onclick = function(){

for(var j=0;j<len2;j++){

divs2[j].style.backgroundColor = "";

}

this.style.backgroundColor = "rgb(65, 117, 252)";

};

}

};

</script>

另外,建议你学学用jQuery吧,好用地很!

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友518f263
2015-01-20 · TA获得超过545个赞
知道小有建树答主
回答量:576
采纳率:90%
帮助的人:219万
展开全部
没必要又复制一遍,你可能变量名没改。为何不把重复的代码用函数封装起来?两个id名分别作为这函数的参数传入,极大地节省电脑资源。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友3c3af2d
推荐于2016-10-04 · TA获得超过292个赞
知道小有建树答主
回答量:196
采纳率:0%
帮助的人:170万
展开全部
这段代码没错 如果你的两个结构是一样的 建议你写成一个方法

可能是你公用了一个len导致的
<script type="text/javascript">

window.onload = function(){

setbc("a1");
setbc("a2");
}

function setbc(id){
var divs = document.getElementById(id).getElementsByTagName("li");
var len = divs.length;
for(var i=0;i<len;i++){
divs[i].onclick = function(){
for(var j=0;j<len;j++){
divs[j].style.backgroundColor = "";
}
this.style.backgroundColor = "rgb(65, 117, 252)";
};
}
}

</script>
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式