其他分享
首页 > 其他分享> > 循环中创建函数的问题

循环中创建函数的问题

作者:互联网

循环中创建函数的问题
//糟糕的例子
var add_handlers = function(nodes){
  var i;
  for(i = 0; i < nodes.length; i++){
    nodes[i].onclick = function (e){
      alert(i);
    };
  }
};
//结束糟糕的例子
//改进的例子
var add_handlers = function(nodes){
  var helper = function(i){
    return function(e){
      alert(i);
    }
  };
  var i;
  for(i=0; i< nodes.length; i+=1){
    nodes[i].onclick = helper(i);
  } 
};

糟糕的例子问题在于事件处理器函数绑定了变量i本身,而不是函数在构造时的变量i的值。

避免在循环中创建函数。

标签:function,函数,创建,糟糕,循环,例子,var,nodes
来源: https://blog.51cto.com/u_15241951/2868673