let的用法
/*
1.let关键字是用来声明变量的
2.let声明的变量具有块级作用域
*/
//经典例题1
var arr = [];
for (var i = 0; i < 2; i++) {
arr[i] = function () {
console.log(i);
};
}
arr[0]();//2
arr[1]();//2
//arr[0]()和rr[1]()都是调用函数arr[i]=function(){console.log(i)},
//此时,arr[0]()作用域范围是没有变量的,根据作用域链法则,向上一层进行查找,
//循环体中存在变量i,由于变量i是由var声明的,不具备块级作用域,是全局变量,
//当循环体执行完之后,i已经变为2了,所以,arr[0]()和arr[1]()函数执行时,输出的变量i为2,结果也都是为2
//总结:变量i为全局变量,函数执行时输出的都是全局作用域下的i值
//经典例题2
let arr1 = [];
for (let i = 0; i < 2; i++) {
arr1[i] = function () {
console.log(i);
};
}
arr1[0]();//0
arr1[1]();//1
//由于let关键字声明的变量具有块级作用域,在执行完循环体之后,产生了两个块级作用域
//产生的块级作用域中都有自己的变量i,互不影响
//arr1[0]()和arr1[1]()函数执行时还是没有变量,向上一层进行寻找,
//也就是循环产生的块级作用域。
//数组中的函数执行时,要分别去寻找各自对应的块级作用域,查找变量i
//所以,数组中第一个函数执行的是第一个块级作用域的变量i,数组中第二个函数执行的是第二个块级作用域中的变量i
//总结:每次循环都会产生一个块级作用域,每个块级作用域的变量i都是不同的,函数执行时输出的是自己上一级(循环产生的块级作用域)作用域下的i变量
const的用法
/*
1.const声明的常量具有块级作用域
2.const声明常量时,常量必须有初始值
3.const声明的常量,赋值后,是不能修改的
*/
const PI = 3.14;
//PI=100;//const声明的普通常量的值是不能更改的
const ary = [100, 200];
ary[0] = 123; //const声明的复杂常量 可以改变内部值 但不能改变内存地址
ary = [1, 2]; //常量对应的内存地址(值)不可更改
console.log(ary); //Uncaught TypeError: Assignment to constant variable
三者的比较:
1.变量起作用的范围是不一样的
2.使用var变量声明的变量不具备块级作用域
3.let声明的变量 const声明的常量都是具有块级作用域的
4.使用var声明的变量存在变量提升,可以先使用,再声明
5.let 声明的变量,只能先声明,再使用
一般实际中 如何使用:如果存储的数据不需要变化,就使用const关键字,比如函数的定义,数学公式 等
原因是,JavaScript引擎也不需要实时监控,所以const关键字要比let关键字效率高 。