|
閉包意味著內(nèi)層的函數(shù)可以引用存在于包圍它的函數(shù)內(nèi)的變量,即使外層函數(shù)的執(zhí)行已經(jīng)終止。
讓我們先來看一個(gè)閉包的例子。
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
代碼①是處于函數(shù)內(nèi)層,不過它可以使用外層的變量num。
閉合還能解決另一個(gè)常見的Js問題,全局變量的影響。
通過自動(dòng)執(zhí)行匿名函數(shù)組合閉包,便可把原本屬于全局的變量隱藏起來。看下面的例子:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
在使用setTimeout時(shí),我們經(jīng)常也用上了閉包。
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
以這種方式使用setTimeout(),可以避免一些問題。
當(dāng)然使用閉包 也會(huì)帶來一些問題。如下代碼所示:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
單擊li彈出的序號(hào)為 3 ,并不是正確的序號(hào),它引用的值是最后一次的賦值。
我們可以使用下面代碼來解決:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
通過使用閉包對(duì)作用域的控制,從而符合了我們的要求。
上面的代碼可以分解為:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執(zhí)行]
閉包的概念不容易掌握,我也是花了大量時(shí)間和精力才理解。
6,小結(jié)
筆記(2),(3),(4)講解了 JavaScript中的幾個(gè)重要的內(nèi)容,包括引用,函數(shù)重載,作用域,上下文對(duì)象和閉包。
引用的關(guān)鍵內(nèi)容: 指針,數(shù)組引用,字符串引用,區(qū)別,傳值,傳址。
函數(shù)重載的關(guān)鍵內(nèi)容: 參數(shù)的數(shù)量,參數(shù)的類型,arguments,偽數(shù)組,typeof,constructor,區(qū)別-字符串和對(duì)象。
作用域的關(guān)鍵內(nèi)容: 函數(shù)劃分,全局作用域,全局對(duì)象,window對(duì)象的屬性,局部作用域,顯式聲明,隱式聲明。
上下文對(duì)象的關(guān)鍵內(nèi)容: this變量,call,apply,參數(shù)區(qū)別,數(shù)組。
閉包的關(guān)鍵內(nèi)容: 內(nèi)層函數(shù),外層函數(shù),變量,setTimeout,閉包問題,最后一次的賦值,閉包和作用域。
JavaScript技術(shù):JavaScript 中級(jí)筆記 第四章 閉包,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。