您好,登錄后才能下訂單哦!
本篇文章為大家展示了javascript中l(wèi)et、var、const三者的區(qū)別是什么,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
1.聲明后未賦值,表現(xiàn)相同
//一個例子 'use strict'; (function() { var varTest; let letTest; console.log(varTest); //輸出undefined console.log(letTest); //輸出undefined }());
2.使用未聲明的變量,表現(xiàn)不同
//一個例子 (function() { console.log(varTest); //輸出undefined(注意要注釋掉下面一行才能運行) console.log(letTest); //直接報錯:ReferenceError: letTest is not defined var varTest = 'test var OK.'; let letTest = 'test let OK.'; }());
3.重復聲明同一個變量時,表現(xiàn)不同
//一個例子 'use strict'; (function() { var varTest = 'test var OK.'; let letTest = 'test let OK.'; var varTest = 'varTest changed.'; let letTest = 'letTest changed.'; //直接報錯:SyntaxError: Identifier 'letTest' has already been declared console.log(varTest); //輸出varTest changed.(注意要注釋掉上面letTest變量的重復聲明才能運行) console.log(letTest); }());
4.變量作用范圍,表現(xiàn)不同
//一個例子 'use strict'; (function() { var varTest = 'test var OK.'; let letTest = 'test let OK.'; { var varTest = 'varTest changed.'; let letTest = 'letTest changed.'; } console.log(varTest); //輸出"varTest changed.",內(nèi)部"{}"中聲明的varTest變量覆蓋外部的letTest聲明 console.log(letTest); //輸出"test let OK.",內(nèi)部"{}"中聲明的letTest和外部的letTest不是同一個變量 }());
5.const定義的變量不可以修改,而且必須初始化
//一個例子 const b = 2;//正確 // const b;//錯誤,必須初始化 console.log('函數(shù)外const定義b:' + b);//有輸出值 // b = 5; // console.log('函數(shù)外修改const定義b:' + b);//無法輸出
6.var定義的變量可以修改,如果不初始化會輸出undefined,不會報錯
var a = 1; // var a;//不會報錯 console.log('函數(shù)外var定義a:' + a);//可以輸出a=1 function change(){ a = 4; console.log('函數(shù)內(nèi)var定義a:' + a);//可以輸出a=4 } change(); console.log('函數(shù)調(diào)用后var定義a為函數(shù)內(nèi)部修改值:' + a);//可以輸出a=4
7.let是塊級作用域,函數(shù)內(nèi)部使用let定義后,對函數(shù)外部無影響
let c = 3; console.log('函數(shù)外let定義c:' + c);//輸出c=3 function change(){ let c = 6; console.log('函數(shù)內(nèi)let定義c:' + c);//輸出c=6 } change(); console.log('函數(shù)調(diào)用后let定義c不受函數(shù)內(nèi)部定義影響:' + c);//輸出c=3
上述內(nèi)容就是javascript中l(wèi)et、var、const三者的區(qū)別是什么,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。