91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

詳談js的變量提升以及使用方法

發布時間:2020-09-17 06:39:22 來源:腳本之家 閱讀:115 作者:laozhang 欄目:web開發

介紹

變量提升Hoisting是人們對JavaScript執行上下文工作方式的一種認識,并不是官方給出的改變

從字面上理解,變量提升的意思是變量和函數的聲明會在物理層移動到作用域的最前面。但是這樣理解并不準確,效果是相同的,但是實際的實現方式是JavaScript的變量和函數的聲明會在編譯階段放入內存

這意味著使用者在正式聲明一個函數或者變量之前就能夠使用它

函數的提升

在JavaScript中,在聲明一個函數前,我們就能夠使用它,大家應該都體驗過,像這樣:

test();

 

function test() {

  // do something

}

在正常的使用情況下,應該需要先聲明函數才能調用,但是這種方法仍然能夠運行,這是因為JavaScript自動將函數聲明事先存入了內存的原因,看起來就像JavaScript自動把函數聲明提升到了最前面

變量的提升

對于變量,JavaScript使用類似的方法,但是要注意一點的是,對于變量的提升,JavaScript只會將變量聲明提升,但是不會把初始化提升,如果在變量初始化之前使用,則會得到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的變量提升是針對var的,而let和const不存在變量提升這一特性

// ReferenceError: a is not defined

console.log(a);

let a = 10;

一個復雜一點的例子

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);

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

丹阳市| 翁源县| 赤峰市| 娄底市| 凉山| 疏附县| 嘉黎县| 昂仁县| 金华市| 西充县| 侯马市| 将乐县| 彩票| 洪洞县| 缙云县| 桓台县| 砚山县| 平山县| 扎鲁特旗| 枞阳县| 莱芜市| 沂源县| 常宁市| 辉县市| 绩溪县| 兴隆县| 如东县| 托克逊县| 五家渠市| 囊谦县| 莱西市| 芜湖市| 高阳县| 兖州市| 奉节县| 浦东新区| 融水| 宁海县| 大埔县| 读书| 崇礼县|