Loading

循环中创建函数的问题

复制代码
//糟糕的例子
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的值。

避免在循环中创建函数。

posted @   stono  阅读(162)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示