您好,登錄后才能下訂單哦!
JavaScript中閉包含義指的是什么?這個(gè)問(wèn)題可能是我們?nèi)粘W(xué)習(xí)或工作經(jīng)常見(jiàn)到的。希望通過(guò)這個(gè)問(wèn)題能讓你收獲頗深。下面是小編給大家?guī)?lái)的參考內(nèi)容,讓我們一起來(lái)看看吧!
閉包是函數(shù)和聲明該函數(shù)的詞法環(huán)境的組合,當(dāng)內(nèi)部函數(shù)被保存到外部時(shí),將會(huì)生成閉包而閉包會(huì)導(dǎo)致原有作用域鏈不釋放,造成內(nèi)存泄露,但同時(shí)閉包也是非常有用的,因?yàn)樗梢詫⒛承?shù)據(jù)與對(duì)該數(shù)據(jù)的操作進(jìn)行關(guān)聯(lián)。
例:
function demo() { var name = '張三'; // name 是demo()創(chuàng)建的局部變量 function demo1() { //demo1()是demo()中的內(nèi)部函數(shù)(閉包) console.log(name); // 使用父函數(shù)中聲明的變量 } demo1(); }demo();
運(yùn)行結(jié)果
函數(shù)demo()中創(chuàng)建一個(gè)名為name的局部變量和一個(gè)名為demo1()的內(nèi)部函數(shù)。 demo1()函數(shù)只能在demo()函數(shù)體內(nèi)使用。 demo1沒(méi)有自己的局部變量。但是由于內(nèi)部函數(shù)可以訪問(wèn)外部函數(shù)的變量,所以demo1()可以訪問(wèn)父函數(shù)demo()中聲明的變量名name。但是如果有同名變量 name 在demo1中被定義,則會(huì)使用 自己函數(shù)中定義的 name。該例子說(shuō)明嵌套函數(shù)可以訪問(wèn)在其外部作用域中聲明的變量。
如果上面的代碼改成這樣結(jié)果會(huì)如何?
function demo() { var name = '張三'; function demo1() { console.log(name); } return demo1; } var newDemo = demo(); newDemo();
運(yùn)行結(jié)果
由運(yùn)行結(jié)果可知兩段代碼結(jié)果一樣,內(nèi)部函數(shù)demo1()在執(zhí)行之前被外部函數(shù)返回形成閉包,在這種情況下,newDemo()是運(yùn)行demo時(shí)所創(chuàng)建的函數(shù)demo1的一個(gè)引用,所以當(dāng)調(diào)用newDemo()時(shí),變量名name仍可以傳遞給console.log(name)。
示例
function num(x) { return function(y) { return x + y; };} var num1= num(2); var num2 = num(3); console.log(num1(2));// 4 console.log(num2(2));// 5
運(yùn)行結(jié)果
定義一個(gè)函數(shù)num(x)用于接收一個(gè)參數(shù)x并返回一個(gè)新函數(shù),這個(gè)新函數(shù)還接收一個(gè)參數(shù)y并返回x和y之和;同時(shí)又定義了兩個(gè)新的值num1,num2都為閉包且傳值分別為2,3.
感謝各位的閱讀!看完上述內(nèi)容,你們對(duì)JavaScript中閉包含義指的是什么大概了解了嗎?希望文章內(nèi)容對(duì)大家有所幫助。如果想了解更多相關(guān)文章內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。