首頁  >  文章  >  web前端  >  javascript定義變數時有var和沒有var的區別探討_基礎知識

javascript定義變數時有var和沒有var的區別探討_基礎知識

WBOY
WBOY原創
2016-05-16 16:41:321219瀏覽

我們先來看一段程式碼

function show(){ 
alert(abc); 
} 
var abc="defg"; 
show();

有過C 或Java程式設計經驗的人可能會說:「這程序,死定了,變數竟然在引用了該變數的函數後邊定義,bug會滅掉你的。」放在瀏覽器上執行一下,結果怎樣?完美運行!接下來我們就說一下這是咋回事——有var和沒有var定義的變數的差別。

1、沒有var

簡明的說,定義變數時省略var是不安全的,不過是合法的。這時無論變數是在什麼位置定義的,解釋器都會賦予該變數以全域作用域。

2、有var

安全的,合法的。定義的變數的作用域取決於定義的位置。至於作用域具體是什麼,請參考本部落格中「javascript作用域」一文。

這樣,開頭的那個問題可以解決了。函數中的才是abc的定義,只不過值為undefined,這時abc有全域作用域,函數外的只是abc的值的更新。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn