JScript中的'var'定義變量的作用域
更新時(shí)間:2007年03月08日 00:00:00 作者:
都不記得是什么時(shí)候看的JScript的語(yǔ)法教程了,里面說(shuō)在聲明變量時(shí)忽略var關(guān)鍵字是完全合法的。當(dāng)時(shí)也因?yàn)橛X(jué)得JavaScript是loosely-typed的語(yǔ)言,所以var可能真的就是個(gè)擺設(shè)。但是事實(shí)常常又證明想當(dāng)然的結(jié)果是不可靠的。
看看下面這幾個(gè)例子的結(jié)果就知道問(wèn)題了:
No.1
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
No.2
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
No.3
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
這三個(gè)例子的執(zhí)行結(jié)果分別是:
Results#region Results
No.1
0
undefined
No.2
0
1
No.3
0
undefined
#endregion
原來(lái)JavaScript的變量也是有作用域的,只是它非常的籠統(tǒng),就分為全局變量和函數(shù)變量。在第二個(gè)例子中得到0和1,是因?yàn)樗械淖兞慷际侨肿兞?,而且那個(gè)語(yǔ)句塊一共就定義了兩個(gè)變量。而第一個(gè)第三的函數(shù)外全局變量,確實(shí)說(shuō)明var關(guān)鍵字有沒(méi)有都沒(méi)有關(guān)系。而函數(shù)內(nèi)的var關(guān)鍵字就很關(guān)鍵了,它說(shuō)明第二個(gè)var01是函數(shù)內(nèi)的變量,所以在初始化var01前輸出自然就是'undefined'了。
那么函數(shù)里面是不是就屏蔽掉了全局的var01了呢?我們知道在C/C++可以使用::去訪問(wèn)全局變量,那么JavaScript可不可以呢?這里其實(shí)我們只要明白了全局變量到底是什么東西,就好弄了。原來(lái)全局變量都是動(dòng)態(tài)添加到Window對(duì)象的實(shí)例window上的屬性而以,所以我們只要在函數(shù)內(nèi)用:document.write(window.var01);就可以取到其值1了。同時(shí)在這個(gè)上下文中,function內(nèi)的this也是指向的window實(shí)例,我們也可以把引用寫成:this.var01。
By the way, 重看JScript教程時(shí),它說(shuō)變量只能是[a-zA-Z_]+[a-zA-Z0-9_]*格式,可是'$'卻也可以作為變量名字符,而且還可以用在開頭,比如:$1234,更甚至于:$$$ 也是合法的變量名,faint。
看看下面這幾個(gè)例子的結(jié)果就知道問(wèn)題了:
No.1
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
No.2
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
No.3
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁(yè)面才能執(zhí)行]
這三個(gè)例子的執(zhí)行結(jié)果分別是:
復(fù)制代碼 代碼如下:
Results#region Results
No.1
0
undefined
No.2
0
1
No.3
0
undefined
#endregion
原來(lái)JavaScript的變量也是有作用域的,只是它非常的籠統(tǒng),就分為全局變量和函數(shù)變量。在第二個(gè)例子中得到0和1,是因?yàn)樗械淖兞慷际侨肿兞?,而且那個(gè)語(yǔ)句塊一共就定義了兩個(gè)變量。而第一個(gè)第三的函數(shù)外全局變量,確實(shí)說(shuō)明var關(guān)鍵字有沒(méi)有都沒(méi)有關(guān)系。而函數(shù)內(nèi)的var關(guān)鍵字就很關(guān)鍵了,它說(shuō)明第二個(gè)var01是函數(shù)內(nèi)的變量,所以在初始化var01前輸出自然就是'undefined'了。
那么函數(shù)里面是不是就屏蔽掉了全局的var01了呢?我們知道在C/C++可以使用::去訪問(wèn)全局變量,那么JavaScript可不可以呢?這里其實(shí)我們只要明白了全局變量到底是什么東西,就好弄了。原來(lái)全局變量都是動(dòng)態(tài)添加到Window對(duì)象的實(shí)例window上的屬性而以,所以我們只要在函數(shù)內(nèi)用:document.write(window.var01);就可以取到其值1了。同時(shí)在這個(gè)上下文中,function內(nèi)的this也是指向的window實(shí)例,我們也可以把引用寫成:this.var01。
By the way, 重看JScript教程時(shí),它說(shuō)變量只能是[a-zA-Z_]+[a-zA-Z0-9_]*格式,可是'$'卻也可以作為變量名字符,而且還可以用在開頭,比如:$1234,更甚至于:$$$ 也是合法的變量名,faint。
您可能感興趣的文章:
- 在Javascript中 聲明時(shí)用"var"與不用"var"的區(qū)別
- javascript定義變量時(shí)加var與不加var的區(qū)別
- JavaScript中var關(guān)鍵字的使用詳解
- js for循環(huán),為什么一定要加var定義i變量
- JavaScript中const、var和let區(qū)別淺析
- 淺析JavaScript中var that=this
- Javascript var變量隱式聲明方法
- 關(guān)于JavaScript中var聲明變量作用域的推斷
- javascript定義變量時(shí)有var和沒(méi)有var的區(qū)別探討
- JavaScript ES6中const、let與var的對(duì)比詳解
- JavaScript中var的重要性實(shí)例分析
相關(guān)文章
使用clipboard.js庫(kù)實(shí)現(xiàn)復(fù)制剪切功能
這篇文章介紹了clipboard.js實(shí)現(xiàn)復(fù)制功能的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-06-06
JS庫(kù)之Three.js 簡(jiǎn)易入門教程(詳解之一)
three.js是一款webGL框架,由于其易用性被廣泛應(yīng)用。下面腳本之家小編通過(guò)案例給大家闡述three.js的基本配置方法,具體內(nèi)容詳情大家參考下本文吧2017-09-09
JavaScript?中的運(yùn)算符和表達(dá)式介紹(二)
這篇文章主要介紹了JavaScript?中的運(yùn)算符和表達(dá)式介紹,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09
js中eval方法詳解之eval方法的初級(jí)應(yīng)用
js中eval()函數(shù)可計(jì)算某個(gè)字符串,下面這篇文章主要給大家介紹了關(guān)于js中eval方法詳解之eval方法的初級(jí)應(yīng)用的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
24個(gè)實(shí)用JavaScript?開發(fā)技巧
這篇文章主要給大家分享了24個(gè)實(shí)用JavaScript?的開發(fā)技巧,文章圍繞JavaScript?的開發(fā)技巧講解展開全文,具有一定的參考價(jià)值,需要的朋友可以參考一下,希望對(duì)你有所幫助2021-12-12
JavaScript?弱引用強(qiáng)引用底層示例詳解
這篇文章主要為大家介紹了JavaScript?弱引用強(qiáng)引用底層示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
jQuery實(shí)現(xiàn)div浮動(dòng)層跟隨頁(yè)面滾動(dòng)效果
這篇文章主要介紹了jQuery實(shí)現(xiàn)div浮動(dòng)層跟隨頁(yè)面滾動(dòng)效果,需要的朋友可以參考下2014-02-02
JavaScript控制各種瀏覽器全屏模式的方法、屬性和事件介紹
瀏覽器全屏模式的啟動(dòng)函數(shù)requestFullscreen仍然需要附帶各瀏覽器的js方言前綴,相信下面這段代碼需要你花大量的搜索才能湊齊:2014-04-04

