(1)Es5之前的作用域
在Es5之前只有全局作用域和函数作用域。
(1)全局作用域
范围:在winodw全局里面都生效
例子:
for(var i=0;i<=5;i++){
}
console.log(window.i===i);
返回的结果是:True
(2)函数作用域
范围:在这个函数里面生效
例子:
function fn(b) {
console.log(b);
}
console.log(b);
fn(10);
返回的结果:
(3)在Es6中推出了块级作用域
1.代码:
for (let i = 0; i <= 5; i++) {}
console.log(window.i === i);
2.输出结果:
console.log(window.i);
3.输出的结果1:
underfined
(4)没有挂载到window挂载到哪儿去了?
1.代码:
for (var i = 0; i < 5; i++) {
setTimeout(function () {
console.log(i);
}, 1000);
}
2.结果:
3.代码1
for (let i = 0; i < 5; i++) {
setTimeout(function () {
console.log(i);
}, 1000);
}
4.结果1:
5.块级作用域的图示:
6.不是块级的图示:
(4)案例
for (let i = 0; i < 5; i++) {
console.log(i);
}
(1)块级的结果:
for (var i = 0; i < 5; i++) {
console.log(i);
}
(2)不是块级的结果:
(5)案例
代码1:
function f1() {
let n = 5;
if (true) {
let n = 10;
}
console.log(n); // 5
}
f1()
分析:调用f1这个函数,可以看出f1这个函数里面使用的let有自己的块级作用域,在if(){ let n}
在这个括号里面有定义了自己的块级作用域
代码2:
function f1() {
var n = 5;
if (true) {
var n = 10;
}
console.log(n); // 5
}
f1();
分析:
预解析:
var n
n=5
n=10
输出结果:
10
(6)总结
在Es5之前只有函数作用域和全局作用域,Es6之后推出了块级作用域,使定义变量更加的规范,更加的合理。