談?wù)勎覍avaScript原型和閉包系列理解(隨手筆記8)
在上篇文章給大家介紹了《談?wù)勎覍avaScript原型和閉包系列理解(隨手筆記6)》, 談?wù)勎覍avaScript原型和閉包系列理解(隨手筆記9) 可以點(diǎn)擊了解詳情。
執(zhí)行上下文棧
執(zhí)行全局代碼時,會產(chǎn)生一個執(zhí)行上下文環(huán)境,每次調(diào)用函數(shù)都又會產(chǎn)生執(zhí)行上下文環(huán)境。當(dāng)函數(shù)調(diào)用完成時,這個上下文環(huán)境以及其中的數(shù)據(jù)都會被消除,再重新回到全局上下文環(huán)境。處于活動狀態(tài)的執(zhí)行上下文環(huán)境只有一個。
壓棧出棧過程----執(zhí)行上下文棧:

var a = 10, //1. 進(jìn)入全局上下文環(huán)境
fn,
bar = function(x) {
var b = 5;
fn(x + b); //3. 進(jìn)入fn函數(shù)上下文
};
fn = function(y) {
var c = 5;
console.log(y + c);
};
bar(10); //2. 進(jìn)入bar函數(shù)上下文環(huán)境
1、在執(zhí)行之前,首先創(chuàng)建全局上下文環(huán)境

2、代碼執(zhí)行,執(zhí)行到bar(10)之前,全局上下文中的變量在執(zhí)行過程中被賦值。

3、執(zhí)行到bar(10)調(diào)用bar函數(shù),同時創(chuàng)建該函數(shù)內(nèi)部的執(zhí)行上下文環(huán)境

4、這時候該執(zhí)行上下文環(huán)境進(jìn)行壓棧,設(shè)置為活動狀態(tài)

5、bar函數(shù)執(zhí)行到fn(x + b),調(diào)用fn函數(shù),創(chuàng)建了fn函數(shù)的執(zhí)行上下文,并壓棧,設(shè)置為活動狀態(tài)

6、fn函數(shù)執(zhí)行完畢,fn環(huán)境出棧,被銷毀,釋放內(nèi)存,bar函數(shù)變?yōu)榛顒討B(tài)

7、fn函數(shù)執(zhí)行完畢并銷毀,意味著bar也執(zhí)行完畢了,此時bar函數(shù)環(huán)境出棧,并銷毀。全局環(huán)境變?yōu)榛顒討B(tài)。

到這里這一段代碼的執(zhí)行過程就完畢了。
根據(jù)原作者的描述:
其中上下文環(huán)境的變量賦值過程我省略了許多,因?yàn)槟切┎⒉浑y,一看就知道。
的確!代碼的大概執(zhí)行過程跑完后,就能很清楚的知道各個執(zhí)行環(huán)境中的變量是個怎樣的狀態(tài)。
講到這里,我不得不很遺憾的跟大家說:其實(shí)以上我們所演示的是一種比較理想的情況。有一種情況,而且是很常用的一種情況,無法做到這樣干凈利落的說銷毀就銷毀。這種情況就是偉大的——閉包。要說閉包,咱們還得先從自由變量和作用域說起。
以上內(nèi)容是小編給大家分享我對JavaScript原型和閉包系列理解(隨手筆記8),希望大家喜歡。
相關(guān)文章
javascript獲取select標(biāo)簽選中的值
這篇文章主要介紹javascript獲取select標(biāo)簽選中的值方法,比較實(shí)用,需要的朋友可以參考下。2016-06-06
至2023年最好用的兼容多瀏覽器的原生js復(fù)制函數(shù)copyText
因?yàn)楹笈_需要增加一些復(fù)制一些內(nèi)容非表單中內(nèi)容,那么下面這個函數(shù)就非常的好用了,其實(shí)也是利用了表單的數(shù)據(jù)權(quán)限比較容易突破,下面是具體的實(shí)現(xiàn)函數(shù),大家可以拿走2023-05-05
Layer.js實(shí)現(xiàn)表格溢出內(nèi)容省略號顯示,懸停顯示全部的方法
今天小編就為大家分享一篇Layer.js實(shí)現(xiàn)表格溢出內(nèi)容省略號顯示,懸停顯示全部的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
JS獲取計算機(jī)mac地址以及IP的實(shí)現(xiàn)方法
本篇文章主要是對利用JS獲取計算機(jī)mac地址以及IP的實(shí)現(xiàn)方法進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-01-01
JavaScript中使用構(gòu)造器創(chuàng)建對象無需new的情況說明
JS中創(chuàng)建對象可以直接使用直接量的方式,這里討論的是定義一個構(gòu)造器(function)的情況2012-03-03

