如果在循环中添加了等待触发事件(如click()),循环不会在执行过程等待事件触发,而是会直接完成数组的循环,最后的循环项 i 值会成为数组的长度
for(var i=0;i<tagN.length;i++){
tagN[i].function(){
console.log(i) //输出 i 的最大值6
}
}
如果希望可以在点击事件中获取以 i 为索引得志,可以在循环中为对象添加属性值,把 i 值赋给相应是标签对象
for(var i=0;i<tagN.length;i++){
tagN[i].index=i;
tagN[i].function(){
console.log(this.index) //输出每个标签对应的索引值 i
}
}
还可以使用ES6中的let关键字来代替var声明函数
for(let i=0;i<tagN.length;i++){
tagN[i].function(){
console.log(this.index) //输出每个标签对应的索引值 i
}
}
还可以使用闭包
for (var i = 0; i < 5; i++) {
(function(i) {
$("#app").click(function() {
console.log(i);
});
})(i);
}