6.js基礎(chǔ)--變量的作用域

1.變量作用域

1.如果一個(gè)變量在函數(shù)體內(nèi)部聲明,則該變量的作用域?yàn)檎麄€(gè)函數(shù)體充岛,函數(shù)體外不可引用访诱。

var add = function(){
var a = 1;
}
a+1; // ReferenceError

2.如果兩個(gè)函數(shù)各自聲明了同一個(gè)變量麻蹋,那么該變量只在各自的函數(shù)體內(nèi)起作用。

var foo(){
var a = 1;
console.log(a); ?//1
}
var bar(){
var a= 'A';
console.log(a); // A
}

3.由于js函數(shù)可以嵌套街夭,此時(shí)砰碴,內(nèi)部函數(shù)可以訪問(wèn)外部函數(shù)定義的變量,反過(guò)來(lái)不可以

function outside(){
var outside = 1;
? ? function inside(){
? ? ? ? var inside = 2;
? ? ? ? var add = outside + inside; ? ?//3
? ? ? ? console.log(add); ?
}
? ? ? ?console.log(add); ? // ? referenceError
}

4.如果外部函數(shù)和內(nèi)部函數(shù)重名莱坎,內(nèi)部函數(shù)變量會(huì)覆蓋外部函數(shù)的變量

function out(){
var a = 1;
? ? function in (){
? ? var a = 2;
? ? console.log(a); ?// 2
}
in();
console.log(a); ?
}

2.變量提升

js會(huì)把所有變量的聲明提前到函數(shù)頂部

變量提升和函數(shù)提升是js設(shè)計(jì)缺陷衣式,在其他語(yǔ)言中直接就報(bào)錯(cuò)了

不要使用變量提升與函數(shù)聲明提升,所有變量和函數(shù)遵循先聲明后使用的原則

不要在JS的設(shè)計(jì)缺陷中糾結(jié)檐什,知道后避開(kāi)坑 ?---廖雪峰

3.全局作用域

不在任何一個(gè)函數(shù)內(nèi)定義的變量就具有全局作用域碴卧。實(shí)際上,js有一個(gè)默認(rèn)的全局對(duì)象window乃正,全局作用域的對(duì)象實(shí)際上是綁定到window的一個(gè)屬性住册。

var course = "learn js";
alert(course); ? ?
alert(window.course);

js實(shí)際上只有一個(gè)全局作用域,任何變量(函數(shù)也是),如果沒(méi)有在當(dāng)前的函數(shù)作用域中找到瓮具,就會(huì)繼續(xù)向上查找荧飞,最后如果全局作用域也沒(méi)有找到凡人,則報(bào)ReferenceError.

4.局部作用域

js變量的作用域?qū)嶋H上是函數(shù)的內(nèi)部,在for循環(huán)語(yǔ)句中是無(wú)法定義具有局部作用域的變量:

function foo(){
? ? for(var i = 0;i<100;i++){
? ? ? ? //
? ? }
? ? i+=100; ? //仍然可以引用變量i
}

為了解決塊級(jí)作用域叹阔,ES6引入了新的關(guān)鍵字let,可以聲明一個(gè)塊級(jí)作用域挠轴。

function foo(){
var sum =0;
for(let i=0; i<100; i++) {
? ? ? ? sum += i;?
? ?}?
? i +=1; ?// ReferenceError
}

5常量

在ES6之前,通常用全部大寫(xiě)的變量表示這是一個(gè)常量耳幢,不可修改值岸晦。

var PI = 3.14;

ES6中引入了新的關(guān)鍵字const來(lái)定義常量,const與let都具有塊級(jí)作用域睛藻。

const PI = 3.14

常量一旦聲明启上,不可修改

const(var) ?PI = 3.14;
PI = 3;
console.log(PI); ? ?//chrome報(bào)錯(cuò) ? Identifier 'PI' has already been declared

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市店印,隨后出現(xiàn)的幾起案子冈在,更是在濱河造成了極大的恐慌,老刑警劉巖按摘,帶你破解...
    沈念sama閱讀 212,816評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件包券,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡院峡,警方通過(guò)查閱死者的電腦和手機(jī)兴使,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)照激,“玉大人,你說(shuō)我怎么就攤上這事盹牧×├” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,300評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵汰寓,是天一觀的道長(zhǎng)口柳。 經(jīng)常有香客問(wèn)我,道長(zhǎng)有滑,這世上最難降的妖魔是什么跃闹? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,780評(píng)論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮毛好,結(jié)果婚禮上望艺,老公的妹妹穿的比我還像新娘。我一直安慰自己肌访,他們只是感情好找默,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,890評(píng)論 6 385
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著吼驶,像睡著了一般惩激。 火紅的嫁衣襯著肌膚如雪店煞。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 50,084評(píng)論 1 291
  • 那天风钻,我揣著相機(jī)與錄音顷蟀,去河邊找鬼。 笑死骡技,一個(gè)胖子當(dāng)著我的面吹牛鸣个,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播哮兰,決...
    沈念sama閱讀 39,151評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼毛萌,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了喝滞?” 一聲冷哼從身側(cè)響起阁将,我...
    開(kāi)封第一講書(shū)人閱讀 37,912評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎右遭,沒(méi)想到半個(gè)月后做盅,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡窘哈,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,666評(píng)論 2 327
  • 正文 我和宋清朗相戀三年吹榴,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片滚婉。...
    茶點(diǎn)故事閱讀 38,809評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡图筹,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出让腹,到底是詐尸還是另有隱情远剩,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評(píng)論 4 334
  • 正文 年R本政府宣布骇窍,位于F島的核電站瓜晤,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏腹纳。R本人自食惡果不足惜痢掠,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,150評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望嘲恍。 院中可真熱鬧足画,春花似錦、人聲如沸蛔钙。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)吁脱。三九已至桑涎,卻和暖如春彬向,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背攻冷。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,121評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工娃胆, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人等曼。 一個(gè)月前我還...
    沈念sama閱讀 46,628評(píng)論 2 362
  • 正文 我出身青樓里烦,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親禁谦。 傳聞我的和親對(duì)象是個(gè)殘疾皇子胁黑,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,724評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容

  • 工廠模式類(lèi)似于現(xiàn)實(shí)生活中的工廠可以產(chǎn)生大量相似的商品,去做同樣的事情州泊,實(shí)現(xiàn)同樣的效果;這時(shí)候需要使用工廠模式丧蘸。簡(jiǎn)單...
    舟漁行舟閱讀 7,729評(píng)論 2 17
  • 1.函數(shù)聲明和函數(shù)表達(dá)式有什么區(qū)別 (*) 區(qū)別: 函數(shù)聲明后面的分號(hào)可加可不加,不加也不影響接下來(lái)語(yǔ)句的執(zhí)行遥皂,但...
    Sheldon_Yee閱讀 396評(píng)論 0 1
  • 單例模式 適用場(chǎng)景:可能會(huì)在場(chǎng)景中使用到對(duì)象力喷,但只有一個(gè)實(shí)例,加載時(shí)并不主動(dòng)創(chuàng)建演训,需要時(shí)才創(chuàng)建 最常見(jiàn)的單例模式弟孟,...
    Obeing閱讀 2,058評(píng)論 1 10
  • 一、作用域 一個(gè)變量的作用域(scope)是程序源代碼中定義的這個(gè)變量的區(qū)域样悟。 1. 在JS中使用的是詞法作用域(...
    掙脫吧小白閱讀 431評(píng)論 0 0
  • 一窟她、理解js作用域 1没讲、作用域:作用域是一套規(guī)則,用于確定在何處以及如何查找變量(標(biāo)字符)礁苗。2、LHS查詢(xún):查找的...
    懷念不能閱讀 457評(píng)論 0 1