js有关变量作用域的问题

Posted zhouboke111

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js有关变量作用域的问题相关的知识,希望对你有一定的参考价值。

上次,我在写一份网页过程中,发现在这样一个函数中

for(var i=0;i<links.length;i++)
{
    links[i].onmouseover=function (){
      console.log(i);
  }
}

输出i的值总是4(我前面有4个a标签),一番折腾下来,好心人告诉我:

这是因为,onmouseover事件在for循环完后才使用(i溢出为全局变量了)

此时i已变为4了。

解决这个问题,可以用传参数的方法。

for(var i=0;i<links.length;i++)
{
     links[i].index=i;
     links[i].onmouseover=function (){
         console.log(this.index);
   }
}

 

以上是关于js有关变量作用域的问题的主要内容,如果未能解决你的问题,请参考以下文章

js作用域与上下文

vue.js学习笔记三

vue.js学习笔记三

vue.js学习笔记三

[JS] 关于变量作用域的 undefined 和 error

理解js中的自由变量以及作用域的进阶