this.inde为什么会是undefined???

for (var i = 0; i < divs.length; i++) {

    divs[i].index = i;
    divs[i].onmouseover=function(){
        console.log(this.index);
        spans[this.index].style.top = start+"px";
    },100)
    }

};
阅读 3.7k
5 个回答

你这样贴代码来看,很不好分析额...但是this.index是可以获取的。

var divs = document.getElementsByTagName('li');  //自己加的
for (var i = 0; i < divs.length; i++) {
  divs[i].index = i;
  divs[i].onmouseover=function(){
      console.log(this.index);
      //spans[this.index].style.top = start+"px";  //不知道spans是个什么对象数组
  }//,100)  //不知道前面放了啥,定时器?如果是定时器,那你的代码都会被放到队列最后,这样写是会有问题的
}
//}; ......

你好好检查下其他代码,用浏览器调试器检查下哪儿报错了。

你应该把相关的代码都贴出来,比如相关的html代码,还有你的divs是否真正获取到了

this是动态绑定的...

看到图中有个数字100,那么猜测,你divs[i].index = i;这一句,实际只给循环的最后一个div赋值了index属性,但是,你hover的时候,缺不是选择的最后一个,所以是undefiend

你那个100是个啥玩意,语法都通不过!

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题