ES5中作用域链、闭包、this的理解

先记住口诀:

(1)作用域链实际上是对象列表,其中每个对象表示一个作用域,其中的属性即为变量名
(2)当函数作为对象的方法调用时,其内的 this 指向该对象;当函数只作为函数调用时,
其内的 this 为 window (非严格模式) 或 undefined(严格模式)。[参考:《JavaScript权威指南》]
下面通过具体的案例来理解上面两句话的含义:

代码1:

for (var i = 0; i < 5; i++) {
    setTimeout(function() {
        console.log(new Date, i);
    }, 1000);
}
console.log(new Date, i);

上述代码的 for 循环没执行一次,其 setTimeout() 中的函数都会放到回调队列中,当其他代码都执行完成(即此时 i = 5),才会从回调队列中调出存入的函数并依次执行。根据口诀 1 ,因为最后 i = 5,所以上述程序的最终输出结果为:
5 => 这是 for 循环外 console.log() 执行的结果
5 5 5 5 5 => 这是 setTimeout() 中函数执行的结果

参考文献

[1] 关于JavaScript 事件循环:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/EventLoop
[2] 事件循环的视频教程:https://www.youtube.com/watch?v=8aGhZQkoFbQ&t=42s

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值