標籤:閉包 私人化 js json
在前幾篇文章中我介紹過js的閉包,這一篇主要簡單的介紹一下js中閉包的範式。
那麼何謂閉包的範式呢?
首先回顧一下閉包的概念,閉包是外部函數與函數內部之間通訊的橋樑,通過對函數的返回,使得外部的函數可以訪問函數內部的
一些資料。也就是說閉包可以使得函數內部的資料私人化或者說是公有化。
範式實際上就是js中的匿名函數,看起來像這樣,下面就是個匿名函數,也就是閉包
(function(){ })()既然是函數,那同樣也可以傳遞參數,在匿名函數中的參數傳遞看起來像下面這樣子:
(function(b){ })(a)其中a是實參,b是形參。當讓我們也可以傳遞多個參數了。
上面講過閉包可以實現資料的私人化和公有化,那麼範式如何解決這個問題呢?我在這裡舉一個簡單的例子:
(function(window){ var name = ‘function‘; function getFunctions(){ return { fb:fb,//公開的函數 fc:fc }; } function fa(){ console.info(‘fa‘); } function fb(){ console.info(‘fb‘); } function fc(){ console.info(‘fc‘); } function fd(){ console.info(‘fd‘); } window.getFunctions = getFunctions(); })(window); console.info(window.getFunctions.fb());console.info(window.getFunctions.fc());console.info(window.getFunctions.fa());console.info(window.getFunctions.fd());
從上面的js中知道,有一個匿名函數,參數為window,在匿名函數內部把getFunctions()賦給了window的一個屬性,這樣getFunctions()就是公開的,那麼怎樣控制其他的函數公開還是私人呢?在getFunctions()內部我們返回了一個json對象,這個對象包含了兩個方法,也就相當於把getFunctions()中的兩個函數公開了。