一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

var與Javascript變量隱式聲明

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上聲明這個變量!
比如:
復(fù)制代碼 代碼如下:
window. y = "hello";
function func(){
y = "OH, NO!!!";
}
func();
alert(window.y); //#=> display "OH, NO!!!"

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

JavaScript技術(shù)var與Javascript變量隱式聲明,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品亚洲片在线花蝴蝶 | 国产精品视频福利 | 综合免费一区二区三区 | 被公侵犯肉体中文字幕一区二区 | 97碰视频人人做人人爱欧美 | 日本精品免费 | 91色在线观看 | 美女视频黄.免费网址 | 亚洲午夜视频在线 | 国内精品在线视频 | 国产中文字幕在线视频 | 涩涩涩在线视频 | 色综合加勒比 | 国产精品乱码免费一区二区 | 欧美精品免费一区欧美久久优播 | 四虎影视国产在线观看精品 | 美女胸又大又www又黄的网站 | 亚洲一区亚洲二区亚洲三区 | 亚洲国产成人久久一区www | 欧美人人做人人爽人人喊 | 久久综合婷婷 | 婷婷玖玖| 黄视频网站在线观看 | 中文字幕视频网站 | 国产极品精频在线观看 | 久久亚洲精品国产亚洲老地址 | 天天干免费视频 | 国产成人区 | 久久久网站亚洲第一 | 色哟哟免费在线观看 | 午夜网站视频 | 中国一级特黄特色真人毛片 | 国产精品1024永久观看 | 国产精品色综合久久 | 性欧美video另类bd | 国产激情在线视频 | 国产成人在线小视频 | 欧美黄www免费 | 国产成人精品免费大全 | 精品在线看| 高清一区二区三区视频 |