一、let进阶
(1)闭包问题
var arr = [];
for(let i = 0; i< 10 i++){
arr[i] = function(){ //赋值10个函数体的同时,也附带了10个闭包
console.log(i)
}
}
for(var k = 0; k <10; k++){
arr[k]();
}
//输出0-9
//通过函数形式形成作用域
var arr = [];
var _loop = function _loop(i) { //每次循环i拿的是闭包参数的i,和全局没有关系,全局的i是10
arr[i] = function() {
console.log(i);
};
};
for (var i = 0; i < 10; i++) {
arr[i]();
};
//通过let直接生成块级作用域
{
let i = 0; //这里也形成了闭包,每次循环i拿的是外层作用域的i
{
arr[i] = function(){
console.log(i);
};
};
};
(2)块级作用域下声明函数
{
let a = 0;
function a(){}; //报错,重复声明了
}
{
let a = 1;
{
function a() { } //这里函数声明提升只能提升到当前作用域,不能提升到作用域之外,所以不会报错
}
console.log(a); //1
}
二、conset
三、全部变量与顶层对象
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。