C/C++教程

ES6-3【let进阶、const、全部变量与顶层对象】

本文主要是介绍ES6-3【let进阶、const、全部变量与顶层对象】,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

一、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

三、全部变量与顶层对象

这篇关于ES6-3【let进阶、const、全部变量与顶层对象】的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!