經典JS閉包題

2021-08-25 11:04:32 字數 2150 閱讀 2272

在逛部落格時,看見乙個很有意思的閉包題,發現自己對閉包沒有完全理解,故記錄下來。

先看題目**:

function fun(n,o) 

};}var a = fun(0); a.fun(1); a.fun(2); a.fun(3);//undefined,?,?,?

var b = fun(0).fun(1).fun(2).fun(3);//undefined,?,?,?

var c = fun(0).fun(1); c.fun(2); c.fun(3);//undefined,?,?,?

//問:三行a,b,c的輸出分別是什麼?

這是一道非常典型的js閉包問題。其中巢狀了三層fun函式,搞清楚每層fun的函式是那個fun函式尤為重要。

可以先在紙上或其他地方寫下你認為的結果,然後看看正確答案是什麼?

1、第一行a

var a = fun(0);  a.fun(1);  a.fun(2);  a.fun(3);
可以得知,第乙個fun(0)是在呼叫第一層fun函式。第二個fun(1)是在呼叫前乙個fun的返回值的fun函式,所以:

第後面幾個fun(1),fun(2),fun(3),函式都是在呼叫第二層fun函式

遂:在第一次呼叫fun(0)時,o為undefined;

第二次呼叫fun(1)時m為1,此時fun閉包了外層函式的n,也就是第一次呼叫的n=0,即m=1,n=0,並在內部呼叫第一層fun函式fun(1,0);所以o為0;

第三次呼叫fun(2)時m為2,但依然是呼叫a.fun,所以還是閉包了第一次呼叫時的n,所以內部呼叫第一層的fun(2,0);所以o為0

第四次同理;

即:最終答案為undefined,0,0,0

2、第二行b

var b = fun(0).fun(1).fun(2).fun(3);//undefined,?,?,?
先從fun(0)開始看,肯定是呼叫的第一層fun函式;而他的返回值是乙個物件,所以第二個fun(1)呼叫的是第二層fun函式,後面幾個也是呼叫的第二層fun函式。

遂:在第一次呼叫第一層fun(0)時,o為undefined;

第二次呼叫 .fun(1)時m為1,此時fun閉包了外層函式的n,也就是第一次呼叫的n=0,即m=1,n=0,並在內部呼叫第一層fun函式fun(1,0);所以o為0;

第三次呼叫 .fun(2)時m為2,此時當前的fun函式不是第一次執行的返回物件,而是第二次執行的返回物件。而在第二次執行第一層fun函式時時(1,0)所以n=1,o=0,返回時閉包了第二次的n,遂在第三次呼叫第三層fun函式時m=2,n=1,即呼叫第一層fun函式fun(2,1),所以o為1;

第四次呼叫 .fun(3)時m為3,閉包了第三次呼叫的n,同理,最終呼叫第一層fun函式為fun(3,2);所以o為2;

即最終答案:undefined,0,1,2

3、第三行c

var c = fun(0).fun(1);  c.fun(2);  c.fun(3);//undefined,?,?,?
根據前面兩個例子,可以得知:

fun(0)為執行第一層fun函式,.fun(1)執行的是fun(0)返回的第二層fun函式,這裡語句結束,遂c存放的是fun(1)的返回值,而不是fun(0)的返回值,所以c中閉包的也是fun(1)第二次執行的n的值。c.fun(2)執行的是fun(1)返回的第二層fun函式,c.fun(3)執行的是fun(1)返回的第二層fun函式。

遂:在第一次呼叫第一層fun(0)時,o為undefined;

第二次呼叫 .fun(1)時m為1,此時fun閉包了外層函式的n,也就是第一次呼叫的n=0,即m=1,n=0,並在內部呼叫第一層fun函式fun(1,0);所以o為0;

第三次呼叫 .fun(2)時m為2,此時fun閉包的是第二次呼叫的n=1,即m=2,n=1,並在內部呼叫第一層fun函式fun(2,1);所以o為1;

第四次.fun(3)時同理,但依然是呼叫的第二次的返回值,遂最終呼叫第一層fun函式fun(3,1),所以o還為1

傳遞閉包經典題

傳遞閉包 給了 a 與 b 的關係,又給了 b 與 c 的關係,我們可以推測出 a 與 c 的關係,這個過程就是傳遞閉包。過程for k,1 n for i,1 n for j,1 n 傳遞閉包經常與 typo 一起使用,在傳遞閉包求出先後 比較 優先順序關係之後用 typo sort 求出這個順序...

JS經典閉包例項

function fun n,o var a fun 0 a.fun 1 a.fun 2 a.fun 3 var b fun 0 fun 1 fun 2 fun 3 var c fun 0 fun 1 c.fun 2 c.fun 3 複製 問 三行a,b,c的輸出分別是什麼?首先來看第一行 var ...

js 閉包經典問題超詳細解析

閉包經典問題如下 function test return arr var myarr test for var j 0 j 10 j 本意是想列印1到10,卻列印了10個10,為什麼呢?詳細解釋過程如下 但此時匿名函式的作用域鏈為 scope scopechain 0 test ao scopec...