首頁 > web前端 > js教程 > 淺談JavaScript中定義變數時有無var聲明的區別_javascript技巧

淺談JavaScript中定義變數時有無var聲明的區別_javascript技巧

WBOY
發布: 2016-05-16 16:39:12
原創
1043 人瀏覽過

前段時間回答了一個關於定義變數時使用關鍵字var與否的區別,總結回顧一下。

1.在函數作用域內 加var定義的變數是局部變量,不加var定義的就成了全域變數。
使用var定義:

var a = 'hello World';
function bb(){
 var a = 'hello Bill';
 console.log(a);  
}
bb()      //'hello Bill'
console.log(a);  //'hello world'
登入後複製

不使用var定義:

var a = 'hello World';
function bb(){
 a = 'hello Bill';
 console.log(a);  
}
bb()      //'hello Bill'
console.log(a);  //'hello Bill'
登入後複製

2.在全域作用域下,使用var定義的變數不可以delete,沒有var 定義的變數可以delete.也就說明隱含全域變數嚴格來說不是真正的變量,而是全域物件的屬性,因為屬性可以透過delete刪除,而變數不可以。

3.使用var 定義變數也會提升變數聲明,即
使用var定義:

function hh(){
 console.log(a);
 var a = 'hello world';
}
hh()      //undefined
登入後複製

不使用var定義:

function hh(){
 console.log(a);
 a = 'hello world';
}
hh()      //'a is not defined'
登入後複製

這就是使用var定義的變數的宣告提前。

4.在ES5的'use strict'模式下,如果變數沒有使用var定義,就會報錯。

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板