如何用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编写的.
展开
 我来答
到茧照
2008-07-08 · TA获得超过1901个赞
知道大有可为答主
回答量:1589
采纳率:0%
帮助的人:1999万
展开全部
你的<li>是GridView或者DataList循环出来的?

或者说.你想实现什么样儿的效果?为什么要这么写?

不管你的<li>是手工写的还是循环出来的.你都可以直接这么写:

<li onmouseover="test(this)"></li>
<script>
<!--
function test(obj){
//这里的obj就是当前的<li>.要怎么操作你自己决定.
}
//-->
</script>

-------------------

哦哦.原来是这样儿..那相当简单了..用css就可以.这么写:

<li>aaa</li>
<style>
li{ exp:expression(onmouseover = function(){this.style.color='red'},onmouseout = function(){this.style.color='black'});
}
</style>
ztk747
2008-07-08 · 超过14用户采纳过TA的回答
知道答主
回答量:76
采纳率:0%
帮助的人:46.6万
展开全部
obj.onmouseover = function()
{
alert(i);
}
这种方法只有最后一个才有效果,需要改成这个样子的,
var li_o = document.getElementsByTagName("li");
for(var i=0;i<li_o.length;i++)
{
var obj = li_o[i];
if (obj.addEventListener) {
obj.addEventListener( "mouseover", cgbj, false );
}
else if (obj.attachEvent) {
obj.attachEvent( "onmouseover", cgbj );
}
}
function cgbj(e)
{
e = window.event || e;
var srcElement = e.srcElement || e.target;
srcElement.style.background="blue";
//鼠标经过变色
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
huangjing_eric
2008-07-08 · TA获得超过103个赞
知道答主
回答量:40
采纳率:0%
帮助的人:36.4万
展开全部
var lis = document.getElementsByTagName("li");
for(var i=0;i<lis.length;i++) {
lis[i].setAttribute("index",i+1);//为兼容forefox,index可改成title
lis[i].onmouseover = function() {
this.style.background="red";
alert(this.index) //上面改成title以后,这行相应改成his.title
}
lis[i].onmouseout = function() {
this.style.background="";
}
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
shaohuabaishuo
推荐于2016-09-20 · TA获得超过307个赞
知道答主
回答量:119
采纳率:100%
帮助的人:29.9万
展开全部
<script>
document.getElementById('a').onmouseover=function(){
写代码

}
</script>

<ul>
<li id='a'></li>
</ul>
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
jian4364
2019-08-15 · TA获得超过282个赞
知道答主
回答量:160
采纳率:0%
帮助的人:50.5万
展开全部
$("#cssmenu li").each(function () {
this.onmouseenter = function () {
this.style.background = 'rgb(51,51,51)';
};
this.onmouseleave = function () {
this.style.background = 'rgb(0,0,0)';
};

});
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式