maxxxxx_ 2021-07-06 18:54 采纳率: 66.7%
浏览 30
已采纳

js图片修改在for循环里就找不到图片地址,单独绑定就可以执行

img

js图片修改在for循环里就找不到图片地址,单独绑定就可以执行,这是什么原因

  • 写回答

1条回答 默认 最新

  • 关注

    因为你需要在事件内使用事件外的循环变量i。
    当事件触发时,那个循环早就结束了,那时的i的值已经是循环最大值加1了。
    所以需要用一些方式保存住当前循环的i的值。

    方案一:用闭包保存住当前循环的i的值

    for (var i = 0; i < arr.length; i++) {
        (function(i){
            arr[i].onclick = function () {
                alert(i);
            }
        })(i);
    }
    

    方案二:用let块作用域变量

    for (var i = 0; i < arr.length; i++) {
        let k = i;
        arr[i].onclick = function () {
            alert(k);
        }
    }
    

    ps:IE11中在for语的()内声明的let是整个循环体中共用的,只有在{}内声明的let才是每次循环都独立的。
    非ie的浏览器中可以在中在for语的()内声明let

    for (let i = 0; i < arr.length; i++)
    

    方案三:为事件元素设置一个index属性,在事件函数内通过this获取当前对象并访问index属性。

    for (var i = 0; i < arr.length; i++) {
        arr[i].index = i;
        arr[i].onclick = function () {
            alert(this.index);
        }
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度
  • ¥30 关于#r语言#的问题:如何对R语言中mfgarch包中构建的garch-midas模型进行样本内长期波动率预测和样本外长期波动率预测