天天看點

javascript中錯誤使用var造成undefined

在javascript中根據變量作用的範圍不同分為局部變量和全局變量,直接定義的變量是全局變量,全局變量可以被所有的腳本通路;在函數中定義的變量是局部變量,局部變量隻在函數内有效。

如果全局變量和局部變量使用相同的變量名,則局部變量将會覆寫全局變量。

例子代碼:

運作的結果是這樣的:

點選test1 ,彈出局部變量。

點選test2,彈出undefined,再彈出局部變量

點選test3,彈出全局變量,再彈出局部變量

這就是使用var和不使用的差別所在:

如果使用var,那麼程式會強制定義一個新變量。

如果沒有使用var,系統會優先在目前上下文中搜尋是否存在該變量,隻有在不存在的前提下才會重新定義一個新變量。

test3中,使用的變量a均為全局變量,第一次直接輸出了全局變量,第二次是直接為全局變量指派之後使用。

test1和test2中都存在在function中使用var定義同名新變量,會導緻函數中的變量覆寫掉全局變量。是以在test2中:第一次輸出的a是已經被覆寫了的局部變量a,但是沒有給予初值,是以會出現undefined這個結果。這樣使用變量實際上是錯誤的,大家應該避免。

繼續閱讀