網站首頁 語言 會計 網際網路計算機 醫學 學歷 職場 文藝體育 範文
當前位置:學識谷 > 設計製作 > 網頁設計

javascript閉包的高階使用方法

欄目: 網頁設計 / 釋出於: / 人氣:3.15W

擴充套件

javascript閉包的高階使用方法

Code:

複製程式碼 程式碼如下:

var blogModule = (function (my) {

hoto = function () {

//新增內部程式碼

};

return my;

}(blogModule));

Say:

將自身傳進方法,然後實現了方法的擴充套件,有點象零件組裝啊

Code:

複製程式碼 程式碼如下:

var blogModule = (function (my) {var oldAddPhotoMethod = hoto;

hoto = function () { // 過載方法,依然可通過oldAddPhotoMethod呼叫舊的方 }; return my;}(blogModule));

Say:

好處就是可以呼叫以前的`方法。

克隆與繼承

Code:

複製程式碼 程式碼如下:

var blogModule = (function (old) { var my = {}, key; for (key in old) { if (wnProperty(key)) { my[key] = old[key]; } } var oldAddPhotoMethod = hoto; hoto = function () { // 克隆以後,進行了重寫,當然也可以繼續呼叫oldAddPhotoMethod }; return my; } (blogModule));

Say:

簡單的克隆實現

跨檔案共享私有物件

Code:

複製程式碼 程式碼如下:

var blogModule = (function (my) { var _private = my._private = my._private || {}, _seal = my._seal = my._seal || function () { my._private; my._seal; my._unseal; }, _unseal = my._unseal = my._unseal || function () { my._private = _private; my._seal = _seal; my._unseal = _unseal; }; return my; } (blogModule || {}));

Say:

blogModule._seal()上鎖,_unseal() 開鎖,實現內部變數的私有化。我認為這樣實現並不是最好的,但是我們可以學習下這個開鎖閉鎖的功能。