如何用javascript给<li>赋onmouseover事件? 30
代码如下:varli_o=document.getElementsByTagName("li");for(vari=0;i<li_o.length;i++){varobj...
代码如下:
var li_o = document.getElementsByTagName("li");
for(var i=0;i<li_o.length;i++)
{
var obj = li_o[i];
obj.onmouseover = function()
{
alert(i);
}
}
为何alert出来的都是最后个索引号,也就是有多少个li,弹出来的就是li-1个.
我的目的是使用for给所有的li加上鼠标事件,但做不到,只能给最后一个加上.高人请指点,谢过.
我想鼠标移到<li>上就改变<li>的背景颜色,移开时取消,但我不想一个li一个li地去加,想用for搞定.我的li直接html编写的. 展开
var li_o = document.getElementsByTagName("li");
for(var i=0;i<li_o.length;i++)
{
var obj = li_o[i];
obj.onmouseover = function()
{
alert(i);
}
}
为何alert出来的都是最后个索引号,也就是有多少个li,弹出来的就是li-1个.
我的目的是使用for给所有的li加上鼠标事件,但做不到,只能给最后一个加上.高人请指点,谢过.
我想鼠标移到<li>上就改变<li>的背景颜色,移开时取消,但我不想一个li一个li地去加,想用for搞定.我的li直接html编写的. 展开
7个回答
2021-01-01
展开全部
用闭包就行
var li_o=document.getElementsByTagName("li");
for(vari=0;i<li_o.length;i++){
(function(){
var obj=li_o[i];
obj.onmouseover=function(){alert(i);}
)(i)
}
var li_o=document.getElementsByTagName("li");
for(vari=0;i<li_o.length;i++){
(function(){
var obj=li_o[i];
obj.onmouseover=function(){alert(i);}
)(i)
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
sss
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询
广告 您可能关注的内容 |