摘要:不存在塊級作用域,具有變量提升機制。在同一作用域內只能聲明一次。注意其針對的是和所在的塊級作用域。在編程過程中如果需要變量提升則使用聲明變量,否則采用和聲明變量,以便更好地控制作用域,避免變量的混用不可控。
1、 var、let、const
var不存在塊級作用域,具有變量提升機制。 let和const存在塊級作用域,不存在變量提升。在同一作用域內只能聲明一次。
## var的說明 ## function a(flag){ if(flag){ console.log(value); //結果為undefined,已聲明但未初始化 var value=1; return value; }else{ console.log(value); //仍舊可以訪問到value;值為undefined } } //上述代碼等價于 function a(flag){ var value; if(flag){ value=1; return value; }else{ console.log(value); //仍舊可以訪問到value;值為undefined } }
## let說明 ## function a(flag){ if(flag){ console.log(value); // 報錯,因為value此時位于TDZ(后面講)內,無法訪問 let value=1; return value; }else{ console.log(value); //value is not defined } }
## const說明 ## function a(flag){ if(flag){ console.log(value); // 報錯,因為value此時位于TDZ(后面講)內,無法訪問 const value=1; //const必須在聲明的時候初始化,并且其值無法被重新賦值 return value; }else{ console.log(value); //value is not defined } }
2、const在聲明時需要賦值且無法修改,但如果常量是對象,則對象的屬性可以修改
const obj={ name:"Alisa", age:25 } obj=23; //報錯 obj.age=23; //允許修改
3、TDZ暫存性死區
JavaScript引擎在掃描代碼發現變量聲明時,如果是使用var聲明的變量,則講變量提升至作用域頂部;如果是采用let和const聲明的變量,則將其放到TDZ中。訪問TDZ中的變量會觸發運行時錯誤,只有執行過變量聲明語句后,變量才會從TDZ中移出,然后才可以正常訪問。注意:其針對的是let和const所在的塊級作用域。
if(flag){ console.log(typeof value); //引用錯誤 let value="time"; } console.log(typeof value); //undefined if(flag){ console.log(typeof value); //引用錯誤 let value="time"; }
4、let、const在循環中的應用
//輸出0-9 var funcs=[]; for(let i=0;i<10;i++){ funcs.push(function(){ console.log(i); }) } funcs.forEach(function(func){ func(); //輸出0-9 }) //將上面的let變為const則會報錯,因為i++操作試圖修改const聲明的常量
//遍歷對象 var person={ name:"Alisa", age:23 }; for(let key in person){ console.log(key); //輸出name、age } //將上面的let換位const不會報錯,因為每次key的值并不相同,即每次定義一個新的變量
5、var可能修改全局屬性(如瀏覽器環境下的window對象的屬性),而let和const不會修改只是遮蔽
var RegExp="hello"; console.log(window.RegExp); //"hello" var say="hi"; console.log(window.say); //"hi" let RegExp="hello"; console.log(RegExp); //"hello" console.log(window.RegExp === RegExp); //false const say="hi"; console.log(say); //"hi" console.log(window.say); //undefined
6、實際應用時的tips
使用塊級綁定時:聲明變量默認采用const,只有確實需要改變變量時才使用let。
在編程過程中如果需要變量提升則使用var聲明變量,否則采用let和const聲明變量,以便更好地控制作用域,避免變量的混用、不可控。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/104200.html
摘要:年月,的創造者公司,決定將提交給國際標準化組織,希望這種語言能夠成為國際標準。這表示外層代碼塊不受內層代碼塊的影響。也可以運用于函數及其他文中就簡單介紹這么多,想更加了解新特性的可以自尋查看一下阮一峰的一本入門 ES6新特性 最近在項目中遇到了很多ES6的語法,遇到了不少坑坑洼洼,因此,在這里就簡單介紹一下ES6中的一些新特性 如果想真正的了解ES6和ES5有什么不同,這里推薦看一下...
摘要:一旦聲明,常量的值不能被改變。頂層對象的屬性頂層對象,瀏覽器中指的是對象,在中指的是對象。中新增了兩個命令和,命令用于暴露出模塊對外的接口,而則用于輸入某一模塊。 1.聲明變量的關鍵字:const 和 let JavaScript ES6中引入了另外兩個聲明變量的關鍵字:const和let。在ES6中,我們將很少能看到var了。 const關鍵字 const聲明一個只讀的常量。一旦聲明...
摘要:對象解構對象解構語法在賦值語句的左側使用了對象字面量,例如代碼中,的值被存儲到本地變量中,的值則存儲到變量中。當使用解構賦值語句時,如果所指定的本地變量在對象中沒有找到同名屬性,那么該變量會被賦值為。 現在ES6在很多項目中大量使用。最近我也花時間看了一下《Understanding ECMAScript6》的中文電子書。在這里總結了一些在實際開發中常用的新特性。 塊級作用域 在ES6...
摘要:定義類常用新特性在一個數組或者列表中檢查是否存在一個值還能在字符串中使用除了增強了可讀性語義化,實際上給開發者返回布爾值,而不是匹配的位置。 ES6常用新特性 1. let && const let 命令也用于變量聲明,但是作用域為局部 { let a = 10; var b = 1; } 在函數外部可以獲取到b,獲取不到a,因此例如for循環計數器就適...
摘要:定義類常用新特性在一個數組或者列表中檢查是否存在一個值還能在字符串中使用除了增強了可讀性語義化,實際上給開發者返回布爾值,而不是匹配的位置。 ES6常用新特性 1. let && const let 命令也用于變量聲明,但是作用域為局部 { let a = 10; var b = 1; } 在函數外部可以獲取到b,獲取不到a,因此例如for循環計數器就適...
閱讀 3779·2021-11-25 09:43
閱讀 2199·2021-11-23 10:13
閱讀 831·2021-11-16 11:44
閱讀 2379·2019-08-29 17:24
閱讀 1391·2019-08-29 17:17
閱讀 3486·2019-08-29 11:30
閱讀 2590·2019-08-26 13:23
閱讀 2350·2019-08-26 12:10