介紹
10年積累的成都做網(wǎng)站、成都網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有紅塔免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
變量提升Hoisting是人們對(duì)JavaScript執(zhí)行上下文工作方式的一種認(rèn)識(shí),并不是官方給出的改變
從字面上理解,變量提升的意思是變量和函數(shù)的聲明會(huì)在物理層移動(dòng)到作用域的最前面。但是這樣理解并不準(zhǔn)確,效果是相同的,但是實(shí)際的實(shí)現(xiàn)方式是JavaScript的變量和函數(shù)的聲明會(huì)在編譯階段放入內(nèi)存
這意味著使用者在正式聲明一個(gè)函數(shù)或者變量之前就能夠使用它
函數(shù)的提升
在JavaScript中,在聲明一個(gè)函數(shù)前,我們就能夠使用它,大家應(yīng)該都體驗(yàn)過,像這樣:
test(); function test() { // do something }
在正常的使用情況下,應(yīng)該需要先聲明函數(shù)才能調(diào)用,但是這種方法仍然能夠運(yùn)行,這是因?yàn)镴avaScript自動(dòng)將函數(shù)聲明事先存入了內(nèi)存的原因,看起來就像JavaScript自動(dòng)把函數(shù)聲明提升到了最前面
變量的提升
對(duì)于變量,JavaScript使用類似的方法,但是要注意一點(diǎn)的是,對(duì)于變量的提升,JavaScript只會(huì)將變量聲明提升,但是不會(huì)把初始化提升,如果在變量初始化之前使用,則會(huì)得到undefined
// undefined console.log(a); // ReferenceError: b is not defined console.log(b); var a = 10;
// undefined console.log(num); num = 6; // 6 console.log(num); num += 7; // 13 console.log(num); var num;
// undefined console.log(num); num = 1; // 1 console.log(num); var num = 2; // 2 console.log(num);
這里要注意,JavaScript的變量提升是針對(duì)var的,而let和const不存在變量提升這一特性
// ReferenceError: a is not defined console.log(a); let a = 10;
一個(gè)復(fù)雜一點(diǎn)的例子
var a = 100; function fn() { // undefined console.log(a); var a = 200; // 200 console.log(a); } fn(); // 100 console.log(a); var a; // 100 console.log(a); // 300 var a = 300; console.log(a);
當(dāng)前題目:詳談js的變量提升以及使用方法
網(wǎng)站鏈接:http://jinyejixie.com/article42/iicphc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供服務(wù)器托管、全網(wǎng)營銷推廣、網(wǎng)站策劃、定制網(wǎng)站、網(wǎng)頁設(shè)計(jì)公司、微信小程序
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)