即使是前端大神有時候也會被一些小埋伏給打趴下,即時防患于未然才是王道,今天小千就來給大家介紹幾個JS變量設(shè)置中的小埋伏,拿好小本本。
使用var關(guān)鍵字聲明的變量即顯式聲明變量:如:var abc1 = ‘hello’
js允許不使用var聲明變量即隱式聲明變量:如:abc2 = ‘world’
那么,問題來了,這兩種變量有什么不一樣的地方嗎?
1.如果abc1和abc2 都在全局作用域,在瀏覽器控制臺打印window對象:console.log( window )
如下圖:
上圖可以看到:在全局的變量abc1和abc2都是window對象的屬性,都擁有全局作用域。
2.如果abc1和abc2都在函數(shù)作用域,在瀏覽器控制臺打印window對象?
如下圖:
上圖可以看到:在函數(shù)作用域中abc1不會出現(xiàn)在window對象中,是一個局部變量;而abc2依然是window對象的屬性,擁有全局作用域。
3.如果abc1和abc2 都在全局作用域,都是window對象的屬性,它們是否可以如對象屬性一般可以被刪除呢?
如下圖:
上圖可以看到:使用var聲明的變量abc1并沒有被刪除,依然是window對象的屬性;而不使用var聲明的變量abc2已被刪除掉。
為什么會有這樣的差別呢?
這與默認(rèn)的對象屬性描述符有關(guān)!
如下圖:
上圖可以看到:window對象的屬性abc1的描述符中,configurable: false 表示該屬性不可配置、不可刪除。
如下圖:
上圖可以看到:window對象的屬性abc2的描述符中,configurable: true 表示該屬性可配置、可刪除。
正是對象屬性描述符中的默認(rèn)設(shè)置不一樣,導(dǎo)致了是否可刪除的差異!
在js中變量聲明和函數(shù)聲明會出現(xiàn)‘聲明提升’,js引擎解析執(zhí)行代碼時分為兩個階段:1.預(yù)解析階段;2.逐行執(zhí)行階段。
在預(yù)解析階段變量abc1被聲明并賦初始值為undefined;在逐行執(zhí)行階段變量abc1被賦值為‘hello’;所以,在變量聲明之前打印不會報錯,打印的值為undefined。
最后想學(xué)習(xí)web前端的同學(xué),可以參考千鋒web前端培訓(xùn)班提供的web前端學(xué)習(xí)路線,該學(xué)習(xí)路線對從零基礎(chǔ)小白到web前端初級開發(fā)工程師,web前端高級開發(fā)工程師,后面的web前端大神級開發(fā)工程師都有一個明確清晰的指導(dǎo),根據(jù)千鋒web前端培訓(xùn)機(jī)構(gòu)提供的web前端學(xué)習(xí)路線圖可以讓你對學(xué)習(xí)web前端開發(fā)需要掌握的知識有個清晰的了解,并快速入門web前端開發(fā)。想要獲取前端完整學(xué)習(xí)路線和免費(fèi)的學(xué)習(xí)資料可以添加我們的web前端技術(shù)分享交流qq群:857920838 加群找群管理領(lǐng)取即可,等你來哦~~