日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

js中加“var”和不加“var”的区别,看完觉得这么多年js白学了

發(fā)布時(shí)間:2025/3/8 36 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js中加“var”和不加“var”的区别,看完觉得这么多年js白学了 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

Javascript聲明變量的時(shí)候,雖然用var關(guān)鍵字聲明和不用關(guān)鍵字聲明,很多時(shí)候運(yùn)行并沒有問題,但是這兩種方式還是有區(qū)別的。可以正常運(yùn)行的代碼并不代表是合適的代碼。

var num = 1;

是在當(dāng)前域中聲明變量. 如果在方法中聲明,則為局部變量(local variable);如果是在全局域中聲明,則為全局變量。

而 num = 1;

事實(shí)上是對(duì)屬性賦值操作。首先,它會(huì)嘗試在當(dāng)前作用域鏈(如在方法中聲明,則當(dāng)前作用域鏈代表全局作用域和方法局部作用域etc。。。)中解析 num; 如果在任何當(dāng)前作用域鏈中找到num,則會(huì)執(zhí)行對(duì)num屬性賦值; 如果沒有找到num,它才會(huì)在全局對(duì)象(即當(dāng)前作用域鏈的最頂層對(duì)象,如window對(duì)象)中創(chuàng)造num屬性并賦值。

注意!它并不是聲明了一個(gè)全局變量,而是創(chuàng)建了一個(gè)全局對(duì)象的屬性。

即便如此,可能你還是很難明白“變量聲明”跟“創(chuàng)建對(duì)象屬性”在這里的區(qū)別。事實(shí)上,Javascript的變量聲明、創(chuàng)建屬性以及每個(gè)Javascript中的每個(gè)屬性都有一定的標(biāo)志說明它們的屬性----如只讀(ReadOnly)不可枚舉(DontEnum)不可刪除(DontDelete)等等。

由于變量聲明自帶不可刪除屬性,比較var num = 1 跟 num = 1,前者是變量聲明,帶不可刪除屬性,因此無法被刪除;后者為全局變量的一個(gè)屬性,因此可以從全局變量中刪除。

具體見以下代碼:

?

復(fù)制代碼代碼如下:
// num1為全局變量,num2為window的一個(gè)屬性

?

???????????????????? var num1 = 1;

???????????????????? num2 = 2;

???????????????????? // delete num1;? 無法刪除

???????????????????? // delete num2;? 刪除

???????????????????? function model(){

??????????????????????????? var num1 = 1; // 本地變量

??????????????????????????? num2 = 2;???? // window的屬性

??????????????????????????? // 匿名函數(shù)

??????????????????????????? (function(){

?????????????????????????????????? var num = 1; // 本地變量

?????????????????????????????????? num1 = 2; // 繼承作用域(閉包)

?????????????????????????????????? num3 = 3; // window的屬性

??????????????????????????? }())

???????????????????? }

?

PS. 在ECMAScript5標(biāo)準(zhǔn)中,有一種“嚴(yán)格模式”(Strict Mode)。在嚴(yán)格模式中,為未聲明的標(biāo)識(shí)符賦值將會(huì)拋引用錯(cuò)誤,因此可以防止意外的全局變量屬性的創(chuàng)造。目前一些瀏覽器的新版本已經(jīng)支持。

轉(zhuǎn)載于:https://www.cnblogs.com/liuna/p/6140901.html

總結(jié)

以上是生活随笔為你收集整理的js中加“var”和不加“var”的区别,看完觉得这么多年js白学了的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。