国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 前端技巧|JS變量中你不知道的小埋伏

前端技巧|JS變量中你不知道的小埋伏

來源:千鋒教育
發布人:小千
時間: 2021-03-16 09:18:00 1615857480

      即使是前端大神有時候也會被一些小埋伏給打趴下,即時防患于未然才是王道,今天小千就來給大家介紹幾個JS變量設置中的小埋伏,拿好小本本。

      使用var關鍵字聲明的變量即顯式聲明變量:如:var abc1 = ‘hello’

      js允許不使用var聲明變量即隱式聲明變量:如:abc2 = ‘world’

      那么,問題來了,這兩種變量有什么不一樣的地方嗎?

      1.如果abc1和abc2 都在全局作用域,在瀏覽器控制臺打印window對象:console.log( window )

      如下圖:

1

      上圖可以看到:在全局的變量abc1和abc2都是window對象的屬性,都擁有全局作用域。

      2.如果abc1和abc2都在函數作用域,在瀏覽器控制臺打印window對象?

2

      如下圖:

3

      上圖可以看到:在函數作用域中abc1不會出現在window對象中,是一個局部變量;而abc2依然是window對象的屬性,擁有全局作用域。

      3.如果abc1和abc2 都在全局作用域,都是window對象的屬性,它們是否可以如對象屬性一般可以被刪除呢?

4

      如下圖:

5

      上圖可以看到:使用var聲明的變量abc1并沒有被刪除,依然是window對象的屬性;而不使用var聲明的變量abc2已被刪除掉。

      為什么會有這樣的差別呢?

      這與默認的對象屬性描述符有關!

6

      如下圖:

7

      上圖可以看到:window對象的屬性abc1的描述符中,configurable: false 表示該屬性不可配置、不可刪除。

8

      如下圖:

9

      上圖可以看到:window對象的屬性abc2的描述符中,configurable: true 表示該屬性可配置、可刪除。

      正是對象屬性描述符中的默認設置不一樣,導致了是否可刪除的差異!

      在js中變量聲明和函數聲明會出現‘聲明提升’,js引擎解析執行代碼時分為兩個階段:1.預解析階段;2.逐行執行階段。

      在預解析階段變量abc1被聲明并賦初始值為undefined;在逐行執行階段變量abc1被賦值為‘hello’;所以,在變量聲明之前打印不會報錯,打印的值為undefined。

      最后想學習web前端的同學,可以參考千鋒web前端培訓班提供的web前端學習路線,該學習路線對從零基礎小白到web前端初級開發工程師,web前端高級開發工程師,后面的web前端大神級開發工程師都有一個明確清晰的指導,根據千鋒web前端培訓機構提供的web前端學習路線圖可以讓你對學習web前端開發需要掌握的知識有個清晰的了解,并快速入門web前端開發。想要獲取前端完整學習路線和免費的學習資料可以添加我們的web前端技術分享交流qq群:857920838  加群找群管理領取即可,等你來哦~~

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT