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

首頁 > 編程 > JavaScript > 正文

var與Javascript變量隱式聲明

2019-11-21 01:08:12
字體:
來源:轉載
供稿:網友
var x = "XX";
y ="xxx";
諸如此類。這有一個問題,比如說在代碼中的某一行,我想使用的一個已聲明的變量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 .
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 若羌县| 西充县| 昆明市| 泉州市| 喜德县| 安龙县| 尼勒克县| 临湘市| 保德县| 天柱县| 新昌县| 和硕县| 电白县| 漳州市| 拉孜县| 深泽县| 禹州市| 崇仁县| 盐城市| 武汉市| 肥东县| 伽师县| 泸州市| 彰化市| 慈溪市| 瓮安县| 泸西县| 民权县| 蕲春县| 黄浦区| 佛教| 定兴县| 赤峰市| 屏东县| 长武县| 普兰县| 金寨县| 黑河市| 云龙县| 沅江市| 巍山|