中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

Javascript var變量隱式聲明方法

諸如此類。這有一個問題,比如說在代碼中的某一行,我想使用的一個已聲明的變量x,結果由于打字或者拼寫錯誤,這個變量被寫成y了,結果相當于“隱式”聲明了一個變量y,在實際編程過程中,這種錯誤有時比較難以發現。
除此之外,今天通過同事介紹,了解到這種“隱式聲明”中的別外一個問題。
當你在當前上下文內進行這種“隱式”聲明時,JavaScript引擎會先在當前上下文中尋找是否之前有聲明此變量,如果沒有,再到上一級的上下文中去尋找,如果一直未找到,會最后在window上聲明這個變量!
比如:
復制代碼 代碼如下:
window. y = "hello";
function func(){
y = "OH, NO!!!";
}
func();
alert(window.y); //#=> display "OH, NO!!!"

當上下文中的任意一層有這種“隱式”定義的變量時,那么該層的該變量會被修改,而不會在window上生成一個新的變量。(這種bug也挺討厭的,尤其是封裝的比較復雜的代碼)
比如:
復制代碼 代碼如下:
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技術Javascript var變量隱式聲明方法,轉載需保留來源!

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

主站蜘蛛池模板: 91亚洲免费 | 亚洲久久| 精品视频在线观看 | 91精品国产高清一区二区三区 | 精品欧美一区二区三区久久久小说 | 欧美精品一区二区在线观看 | 欧美xxxx做受欧美 | 午夜av成人 | 精精久久| 国产性网| 国产成人aⅴ | 日韩一区二区在线播放 | 国产乱码精品一区二区三区五月婷 | 一级a性色生活片久久毛片 午夜精品在线观看 | 色999视频 | 久久精品屋 | 狠狠插天天干 | 国产精品一区在线观看 | 久久人人爽人人爽 | 日韩午夜一区二区三区 | 国产在线一区二区三区 | 中文字幕亚洲一区 | 亚洲精品粉嫩美女一区 | 先锋影音资源网站 | 国产福利一区二区 | 日韩久久网 | 91.色| 亚洲国产黄 | 久久成人国产精品 | 国产精品av久久久久久毛片 | 欧美福利视频 | 亚洲国产一区视频 | 精品日韩一区 | 在线视频91| 成人欧美一区二区三区黑人孕妇 | 精品视频一区二区 | 久久国内精品 | 欧美亚洲日本 | 欧美日韩久久精品 | av资源中文在线 | 黄色片免费看 |