一、let和var區別
1.關于變量提升,var能變量提升,let不能
// 關于var 如下所示console.log(a); //輸出undefined,此時就是變量提升var a = 2; console.log(a); //2//相當于下面的代碼var a; //聲明且初始化為undefinedconsole.log(a); //輸出undefineda=2; //賦值console.log(a); //2// 關于let 如下所示console.log(a); // 報錯ReferenceErrorlet a = 2;//相當于在第一行先聲明a但沒有初始化,直到賦值時才初始化//直接用let聲明變量不賦值是會打印undefined,這時候初始化了let a;console.log(a);//值為undefined
2.暫時性死區:塊級作用域內存在let命令,它所聲明的變量就“綁定”這個區域,不再受外部的影響重點內容,簡而言之,就是某個代碼塊有let指令,即使外部有名稱相同的變量,該代碼塊的同名變量與外部的變量也互不干擾。而var不會,如下所示:
//letvar a = 123;if (true) { let a="abc"; console.log(a); //輸出abc }console.log(a); //輸出值為123,全局a與局部a互不影響//varvar a = 123;if (true) { var a="abc"; console.log(a); //輸出abc }console.log(a); //輸出值為abc,全局的已被改變總之,在代碼塊內,使用let命令聲明變量之前,該變量都是不可用的。這在語法上,稱為“暫時性死區”(temporal dead zone,簡稱 TDZ)。例子如下:
var tmp=1;if (true) { // TDZ開始 tmp = 'abc'; // ReferenceError console.log(tmp); // ReferenceError let tmp; // TDZ結束 console.log(tmp); // undefined tmp = 123; console.log(tmp); // 123}console.log(tmp); // 3.let聲明綁定的代碼塊內,不能重復聲明同一個變量,var可以
//a不能重復聲明function sub() { let a = 10; var a = 1;} //報錯,Identifier 'a' has already been declaredfunction sub() { let a = 10; let a = 1;} //同上function sub() { let a = 10; {let a = 1;} //此時不在同一個代碼塊,不會報錯} //var可以重復聲明,不會報錯function sub() { var a = 10; var a = 1;}4.類似for循環的代碼塊,let只在代碼塊內部有效,var在代碼塊外部也有效
//let只在代碼塊內部有效for (let i = 0; i < 10; i++) {}console.log(i); //報錯ReferenceError: i is not defined//var在代碼塊外部也有效for (let i = 0; i < 10; i++) {}console.log(i); //101let在for循環內特別之處:就是設置循環變量的那部分是一個父作用域,而循環體內部是一個單獨的子作用域。//只在父作用域var a = [];for (let i = 0; i < 10; i++) { a[i] = function () { console.log(i); };}a[6](); // 6//子作用域重新聲明var a = [];for (let i = 0; i < 10; i++) { a[i] = function () { let i=3; //重新賦值 console.log(i); };}a[6](); // 3 ,取得新的值
新聞熱點
疑難解答
圖片精選