国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JavaScript聲明變量時為什么要加var關(guān)鍵字

2019-11-20 14:04:45
字體:
供稿:網(wǎng)友

在JavaScript中,var用來聲明變量,但是這個語法并不嚴(yán)格要求,很多時修改,我們可以直接使用一個變量而不用var聲明它。

復(fù)制代碼 代碼如下:

var x = "XX";
y ="xxx";

諸如此類。這有一個問題,比如說在代碼中的某一行,我想使用的一個已聲明的變量x,結(jié)果由于打字或者拼寫錯誤,這個變量被寫成y了,結(jié)果相當(dāng)于“隱式”聲明了一個變量y,在實際編程過程中,這種錯誤有時比較難以發(fā)現(xiàn)。
當(dāng)你在當(dāng)前上下文內(nèi)進(jìn)行這種“隱式”聲明時,JavaScript引擎會先在當(dāng)前上下文中尋找是否之前有聲明此變量,如果沒有,再到上一級的上下文中去尋找,如果一直未找到,會最后在window上聲明這個變量!
比如:

代碼如下:

window. y = "hello"; function func(){ y = "OH, NO!!!"; } func(); alert(window.y); //#=> display "OH, NO!!!" 

當(dāng)上下文中的任意一層有這種“隱式”定義的變量時,那么該層的該變量會被修改,而不會在window上生成一個新的變量。(這種bug也挺討厭的,尤其是封裝的比較復(fù)雜的代碼)
比如:

代碼如下:

var x = "window.x"; function a() { var x = "a's x"; var b = function() { var c = function() { //no var! x = "c's x:"; }; alert("before c run,the b.x:" + x); c(); alert("after c run, the b.x:" + x); }; alert("a.x is:" + x); b(); alert("after b function runed, the a.x is:" + x); }; alert("before a run, window.x:" + x); a(); alert("after a run, window.x:" + x); 

這里面有以下幾層:window, func a, func b, func c一直作層級嵌套。window->a->b->c
window和a中,都有定義變量x,b中未定義該變量,在c中‘隱式'聲明了一個x,該x最終修改了a變量的值。
牢記,在JavaScript中,聲明變量,一定前面要加var .

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 江川县| 共和县| 唐河县| 大庆市| 常山县| 香河县| 清水县| 康定县| 屯昌县| 永新县| 调兵山市| 商河县| 城口县| 葫芦岛市| 洛隆县| 南雄市| 道真| 博爱县| 宣威市| 文成县| 钟祥市| 攀枝花市| 新泰市| 分宜县| 昌邑市| 长垣县| 昭觉县| 敦化市| 景洪市| 海宁市| 连平县| 武强县| 扎赉特旗| 吉林省| 忻城县| 沁源县| 延长县| 会理县| 东丰县| 中江县| 迭部县|