在循环内错误使用函数定义(js的问题)

考虑下面代码:

html 复制代码
var elements = document.getElementsByTagName('input');
var n = elements.length;    // Assume we have 10 elements for this example
for (var i = 0; i < n; i++) {
    elements[i].onclick = function() {
        console.log("This is element #" + i);
    };
}

根据上面的代码,如果有10input 元素,点击任何一个都会显示 "This is element #10"。 这是因为,当任何一个元素的onclick被调用时,上面的for循环已经结束,i的值已经是10了(对于所有的元素)。

我们可以像下面这样来解决这个问题:

html 复制代码
var elements = document.getElementsByTagName('input');
var n = elements.length;   
var makeHandler = function(num) { 
     return function() {  
         console.log("This is element #" + num);
     };
};
for (var i = 0; i < n; i++) {
    elements[i].onclick = makeHandler(i+1);
}

makeHandler 是一个外部函数,并返回一个内部函数,这样就会形成一个闭包,num 就会调用时传进来的的当时值,这样在点击元素时,就能显示正确的序号。

相关推荐
菜鸟一枚在这1 分钟前
深度解析建造者模式:复杂对象构建的优雅之道
java·开发语言·算法
垣宇1 分钟前
Vite 和 Webpack 的区别和选择
前端·webpack·node.js
java1234_小锋4 分钟前
一周学会Flask3 Python Web开发-客户端状态信息Cookie以及加密
前端·python·flask·flask3
化作繁星7 分钟前
如何在 React 中测试高阶组件?
前端·javascript·react.js
Au_ust14 分钟前
千峰React:函数组件使用(2)
前端·javascript·react.js
阿巴~阿巴~19 分钟前
多源 BFS 算法详解:从原理到实现,高效解决多源最短路问题
开发语言·数据结构·c++·算法·宽度优先
爱吃南瓜的北瓜25 分钟前
npm install 卡在“sill idealTree buildDeps“
前端·npm·node.js
TTc_29 分钟前
记录首次安装远古时代所需的运行环境成功npm install --save-dev node-sass
前端·npm·sass
翻滚吧键盘33 分钟前
npm使用了代理,但是代理软件已经关闭导致创建失败
前端·npm·node.js
烂蜻蜓40 分钟前
Uniapp 设计思路全分享
前端·css·vue.js·uni-app·html