javascript閉包的高級使用方法實(shí)例
更新時(shí)間:2013年07月04日 15:49:56 作者:
這篇文章介紹了javascript閉包的高級使用方法實(shí)例,有需要的朋友可以參考一下
擴(kuò)展
Code:
var blogModule = (function (my) {
my.AddPhoto = function () {
//添加內(nèi)部代碼
};
return my;
}(blogModule));
Say:
將自身傳進(jìn)方法,然后實(shí)現(xiàn)了方法的擴(kuò)展,有點(diǎn)象零件組裝啊
Code:
var blogModule = (function (my) {var oldAddPhotoMethod = my.AddPhoto;
my.AddPhoto = function () { // 重載方法,依然可通過oldAddPhotoMethod調(diào)用舊的方 }; return my;}(blogModule));
Say:
好處就是可以調(diào)用以前的方法。
克隆與繼承
Code:
var blogModule = (function (old) { var my = {}, key; for (key in old) { if (old.hasOwnProperty(key)) { my[key] = old[key]; } } var oldAddPhotoMethod = old.AddPhoto; my.AddPhoto = function () { // 克隆以后,進(jìn)行了重寫,當(dāng)然也可以繼續(xù)調(diào)用oldAddPhotoMethod }; return my; } (blogModule));
Say:
簡單的克隆實(shí)現(xiàn)
跨文件共享私有對象
Code:
var blogModule = (function (my) { var _private = my._private = my._private || {}, _seal = my._seal = my._seal || function () { delete my._private; delete my._seal; delete my._unseal; }, _unseal = my._unseal = my._unseal || function () { my._private = _private; my._seal = _seal; my._unseal = _unseal; }; return my; } (blogModule || {}));
Say:
blogModule._seal()上鎖,_unseal() 開鎖,實(shí)現(xiàn)內(nèi)部變量的私有化。我認(rèn)為這樣實(shí)現(xiàn)并不是最好的,但是我們可以學(xué)習(xí)下這個(gè)開鎖閉鎖的功能。
Code:
復(fù)制代碼 代碼如下:
var blogModule = (function (my) {
my.AddPhoto = function () {
//添加內(nèi)部代碼
};
return my;
}(blogModule));
Say:
將自身傳進(jìn)方法,然后實(shí)現(xiàn)了方法的擴(kuò)展,有點(diǎn)象零件組裝啊
Code:
復(fù)制代碼 代碼如下:
var blogModule = (function (my) {var oldAddPhotoMethod = my.AddPhoto;
my.AddPhoto = function () { // 重載方法,依然可通過oldAddPhotoMethod調(diào)用舊的方 }; return my;}(blogModule));
Say:
好處就是可以調(diào)用以前的方法。
克隆與繼承
Code:
復(fù)制代碼 代碼如下:
var blogModule = (function (old) { var my = {}, key; for (key in old) { if (old.hasOwnProperty(key)) { my[key] = old[key]; } } var oldAddPhotoMethod = old.AddPhoto; my.AddPhoto = function () { // 克隆以后,進(jìn)行了重寫,當(dāng)然也可以繼續(xù)調(diào)用oldAddPhotoMethod }; return my; } (blogModule));
Say:
簡單的克隆實(shí)現(xiàn)
跨文件共享私有對象
Code:
復(fù)制代碼 代碼如下:
var blogModule = (function (my) { var _private = my._private = my._private || {}, _seal = my._seal = my._seal || function () { delete my._private; delete my._seal; delete my._unseal; }, _unseal = my._unseal = my._unseal || function () { my._private = _private; my._seal = _seal; my._unseal = _unseal; }; return my; } (blogModule || {}));
Say:
blogModule._seal()上鎖,_unseal() 開鎖,實(shí)現(xiàn)內(nèi)部變量的私有化。我認(rèn)為這樣實(shí)現(xiàn)并不是最好的,但是我們可以學(xué)習(xí)下這個(gè)開鎖閉鎖的功能。
您可能感興趣的文章:
- javascript深入理解js閉包
- 淺析javascript閉包 實(shí)例分析
- 深入理解Javascript閉包 新手版
- Javascript閉包演示代碼小結(jié)
- JavaScript 匿名函數(shù)(anonymous function)與閉包(closure)
- JavaScript閉包 懂不懂由你反正我是懂了
- JavaScript中的作用域鏈和閉包
- 深入Javascript函數(shù)、遞歸與閉包(執(zhí)行環(huán)境、變量對象與作用域鏈)使用詳解
- JavaScript閉包函數(shù)訪問外部變量的方法
- 詳談JavaScript 匿名函數(shù)及閉包
- JavaScript閉包詳解
相關(guān)文章
JavaScript實(shí)現(xiàn)簡單的彈窗效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡單的彈窗效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05javascript getElementByTagName的使用
javascript getElementByTagName當(dāng)鼠標(biāo)放上去時(shí)將超鏈接的顏色設(shè)為藍(lán)色的。2009-06-06基于JavaScript實(shí)現(xiàn)樹形下拉框
這篇文章主要為大家詳細(xì)介紹了基于JavaScript實(shí)現(xiàn)樹形下拉框的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-08-08Javascript將數(shù)字轉(zhuǎn)化成為貨幣格式字符串
這篇文章主要介紹Javascript將數(shù)字轉(zhuǎn)化成為貨幣格式字符串的方法,通俗易懂,需要的朋友可以參考下。2016-06-06