javascript闭包理解之onload事件遍历获取数组元素

我们在学javascript的时候是否遇到过这样的代码,例如我们要在onload事件里循环遍历一个数组,对遍历到的数组元素进行操作。需要用到this对象,如下代码所示:

onload = function () {
            var links = document.getElementsByTagName("a");
            for (var i = 0; i < links.length; i++) {
                links[i].onclick = function () 
                //这样只有最后一个标签的内容可以显示出来 
                    alert(links[i].innerHTML);   
                };
            }
        };


这里对一种类型的标签(假设是浏览器中所有a标签)进行遍历,并获取个当前标签元素,当点击标签时,浏览器会弹出标签中的内容。考虑一下,上面的程序能否执行成功,答案是否定的。很显然,这个遍历写在了onload的事件里了,当浏览器加载完毕后,这个i已经遍历结束了,而在出发onclick事件的时候,我们获取到的是最后一个标签元素。

对于这种情况,我们一般是用this代替links[i],来完成的。那么怎样使用links[i],也可以完成类似的操作呢。闭包就可以解决。如下所示

  onload = function () {
            var links = document.getElementsByTagName("a");
            for (var i = 0; i < links.length; i++) {
                links[i].onclick = (function () {
                    var res = i;
                    //因为闭包内要使用i,所以外层i还依旧存在内存中
                    return function () {
                        alert(links[res].innerHTML);
                        alert(typeof this);
                    }
                })();
            }
        }


这里我是这样理解的,程序运用了闭包原理,而闭包幽灵就是i 变量,它在第二个function()的外面,而function内部引用了i变量,所以导致浏览器在加载的时候保留了i变量遍历结束之前的数据,当某个标签被点击后,便能找到它所在数组的位置,从而对其作出相应的操作。

此段代码亲测,可以执行。至于更深次的理解,需要在不断的学习中探索。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

非正经程序员

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值