這篇文章將為大家詳細(xì)講解有關(guān)JavaScript變量怎么用,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、成都微信小程序、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了寧化免費建站歡迎大家使用!
在JavaScript中,用var
申明的變量實際上是有作用域的。
如果一個變量在函數(shù)體內(nèi)部申明,則該變量的作用域為整個函數(shù)體,在函數(shù)體外不可引用該變量:
'use strict'; function foo() { var x = 1; x = x + 1; } x = x + 2; // ReferenceError! 無法在函數(shù)體外引用變量x
如果兩個不同的函數(shù)各自申明了同一個變量,那么該變量只在各自的函數(shù)體內(nèi)起作用。換句話說,不同函數(shù)內(nèi)部的同名變量互相獨立,互不影響:
'use strict'; function foo() { var x = 1; x = x + 1; } function bar() { var x = 'A'; x = x + 'B'; }
由于JavaScript的函數(shù)可以嵌套,此時,內(nèi)部函數(shù)可以訪問外部函數(shù)定義的變量,反過來則不行:
'use strict'; function foo() { var x = 1; function bar() { var y = x + 1; // bar可以訪問foo的變量x! } var z = y + 1; // ReferenceError! foo不可以訪問bar的變量y! }
如果內(nèi)部函數(shù)和外部函數(shù)的變量名重名怎么辦?
'use strict'; function foo() { var x = 1; function bar() { var x = 'A'; alert('x in bar() = ' + x); // 'A' } alert('x in foo() = ' + x); // 1 bar(); }
這說明JavaScript的函數(shù)在查找變量時從自身函數(shù)定義開始,從“內(nèi)”向“外”查找。如果內(nèi)部函數(shù)定義了與外部函數(shù)重名的變量,則內(nèi)部函數(shù)的變量將“屏蔽”外部函數(shù)的變量。
變量提升
JavaScript的函數(shù)定義有個特點,它會先掃描整個函數(shù)體的語句,把所有申明的變量“提升”到函數(shù)頂部:
'use strict'; function foo() { var x = 'Hello, ' + y; alert(x); var y = 'Bob'; } foo();
雖然是strict模式,但語句var x = 'Hello, ' + y;
并不報錯,原因是變量y
在稍后申明了。但是alert
顯示Hello, undefined
,說明變量y
的值為undefined
。這正是因為JavaScript引擎自動提升了變量y
的聲明,但不會提升變量y
的賦值。
對于上述foo()
函數(shù),JavaScript引擎看到的代碼相當(dāng)于:
function foo() { var y; // 提升變量y的申明 var x = 'Hello, ' + y; alert(x); y = 'Bob'; }
由于JavaScript的這一怪異的“特性”,我們在函數(shù)內(nèi)部定義變量時,請嚴(yán)格遵守“在函數(shù)內(nèi)部首先申明所有變量”這一規(guī)則。最常見的做法是用一個var
申明函數(shù)內(nèi)部用到的所有變量:
function foo() { var x = 1, // x初始化為1 y = x + 1, // y初始化為2 z, i; // z和i為undefined // 其他語句: for (i=0; i<100; i++) { ... } }
全局作用域
不在任何函數(shù)內(nèi)定義的變量就具有全局作用域。實際上,JavaScript默認(rèn)有一個全局對象window
,全局作用域的變量實際上被綁定到window
的一個屬性:
'use strict'; var course = 'Learn JavaScript'; alert(course); // 'Learn JavaScript' alert(window.course); // 'Learn JavaScript'
因此,直接訪問全局變量course
和訪問window.course
是完全一樣的。
你可能猜到了,由于函數(shù)定義有兩種方式,以變量方式var foo = function () {}
定義的函數(shù)實際上也是一個全局變量,因此,頂層函數(shù)的定義也被視為一個全局變量,并綁定到window
對象:
'use strict'; function foo() { alert('foo'); } foo(); // 直接調(diào)用foo() window.foo(); // 通過window.foo()調(diào)用
進(jìn)一步大膽地猜測,我們每次直接調(diào)用的alert()函數(shù)其實也是window的一個變量:
'use strict'; window.alert('調(diào)用window.alert()'); // 把a(bǔ)lert保存到另一個變量: var old_alert = window.alert; // 給alert賦一個新函數(shù): window.alert = function () {} // 恢復(fù)alert: window.alert = old_alert; alert('又可以用alert()了!');
這說明JavaScript實際上只有一個全局作用域。任何變量(函數(shù)也視為變量),如果沒有在當(dāng)前函數(shù)作用域中找到,就會繼續(xù)往上查找,最后如果在全局作用域中也沒有找到,則報ReferenceError錯誤。
名字空間
全局變量會綁定到window
上,不同的JavaScript文件如果使用了相同的全局變量,或者定義了相同名字的頂層函數(shù),都會造成命名沖突,并且很難被發(fā)現(xiàn)。
減少沖突的一個方法是把自己的所有變量和函數(shù)全部綁定到一個全局變量中。例如:
// 唯一的全局變量MYAPP: var MYAPP = {}; // 其他變量: MYAPP.name = 'myapp'; MYAPP.version = 1.0; // 其他函數(shù): MYAPP.foo = function () { return 'foo'; };
把自己的代碼全部放入唯一的名字空間MYAPP
中,會大大減少全局變量沖突的可能。
許多著名的JavaScript庫都是這么干的:jQuery,YUI,underscore等等。
局部作用域
由于JavaScript的變量作用域?qū)嶋H上是函數(shù)內(nèi)部,我們在for
循環(huán)等語句塊中是無法定義具有局部作用域的變量的:
'use strict'; function foo() { for (var i=0; i<100; i++) { // } i += 100; // 仍然可以引用變量i }
為了解決塊級作用域,ES6引入了新的關(guān)鍵字let,用let替代var可以申明一個塊級作用域的變量:
'use strict'; function foo() { var sum = 0; for (let i=0; i<100; i++) { sum += i; } i += 1; // SyntaxError }
常量
由于var
和let
申明的是變量,如果要申明一個常量,在ES6之前是不行的,我們通常用全部大寫的變量來表示“這是一個常量,不要修改它的值”:
var PI = 3.14;
ES6標(biāo)準(zhǔn)引入了新的關(guān)鍵字const來定義常量,const與let都具有塊級作用域:
'use strict'; const PI = 3.14; PI = 3; // 某些瀏覽器不報錯,但是無效果! PI; // 3.14
關(guān)于“JavaScript變量怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
標(biāo)題名稱:JavaScript變量怎么用
本文鏈接:http://www.chinadenli.net/article46/jdjpeg.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供商城網(wǎng)站、靜態(tài)網(wǎng)站、面包屑導(dǎo)航、響應(yīng)式網(wǎng)站、網(wǎng)站設(shè)計、定制網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)