js匿名函數this指向,JS變量中你不知道的小埋伏

 2023-10-06 阅读 16 评论 0

摘要:即使是前端大神有時候也會被一些小埋伏給打趴下,即時防患于未然才是王道,今天小千就來給大家介紹幾個JS變量設置中的小埋伏,拿好小本本。 js匿名函數this指向,使用var關鍵字聲明的變量即顯式聲明變量:如:var abc1 = ‘hello’ js允許

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

js匿名函數this指向,使用var關鍵字聲明的變量即顯式聲明變量:如:var abc1 = ‘hello’

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

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

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

如下圖:

在這里插入圖片描述

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

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

在這里插入圖片描述

如下圖:

在這里插入圖片描述

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

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

在這里插入圖片描述

如下圖:

在這里插入圖片描述

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

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

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

在這里插入圖片描述

如下圖:

在這里插入圖片描述

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

在這里插入圖片描述

如下圖:

在這里插入圖片描述

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

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

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

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

本文來自千鋒教育:http://www.mobiletrain.org/

版权声明:本站所有资料均为网友推荐收集整理而来,仅供学习和研究交流使用。

原文链接:https://hbdhgg.com/1/121423.html

发表评论:

本站为非赢利网站,部分文章来源或改编自互联网及其他公众平台,主要目的在于分享信息,版权归原作者所有,内容仅供读者参考,如有侵权请联系我们删除!

Copyright © 2022 匯編語言學習筆記 Inc. 保留所有权利。

底部版权信息