輕松掌握J(rèn)avaScript代理模式
在面向?qū)ο笤O(shè)計(jì)中,有一個(gè)單一職責(zé)原則,指就一個(gè)類(對象、函數(shù))而言,應(yīng)該僅有一個(gè)引起它變化的原因。如果一個(gè)對象承擔(dān)了過多的職責(zé),就意味著它將變得巨大,引起它變化的原因就多,它把這些職責(zé)耦合到了一起,這種耦合會導(dǎo)致程序難于維護(hù)和重構(gòu)。
這時(shí)候,我們可以把該對象(本體)的其中一部分職責(zé)分離出來給一些第三方對象去做,本體只管自己的一些核心職責(zé),這些第三方對象就稱作代理。代理對象可以作為對象(也叫“真正的主體”)的保護(hù)者,讓真正的主體對象做盡量少的工作。在代理設(shè)計(jì)模式中,一個(gè)對象充當(dāng)了另一個(gè)對象的接口的角色。
通常代理和本體的接口應(yīng)該保持一致性,這樣當(dāng)不需要代理的時(shí)候,用戶可直接訪問本體。
當(dāng)我們不方便直接訪問一個(gè)對象時(shí),就可以考慮給該對象招一個(gè)代理。
代理可用于:圖片預(yù)加載、合并HTTP請求(代理收集一定時(shí)間內(nèi)的所有HTTP請求,然后一次性發(fā)給服務(wù)器)、惰性加載(通過代理處理和收集一些基本操作,然后僅在真正需要本體的時(shí)候才加載本體)、緩存代理(緩存請求結(jié)果、計(jì)算結(jié)果)等
例子1:圖片預(yù)加載
var myImage = (function(){ var imgNode = document.createElement('img'); document.body.appendChild(imgNode); return { setSrc:function(src){ imgNode.src = src; } } })(); //代理函數(shù) var proxyImage = (function(){ var img = new Image; img.onload = function(){ myImage.setSrc(this.src); } return{ setSrc:function(src){ myImage.setSrc('loading.gif'); img.src = src; } } })(); proxyImage.setSrc('show.jpg');
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- JavaScript設(shè)計(jì)模式之代理模式詳解
- JavaScript設(shè)計(jì)模式之代理模式介紹
- JavaScript的設(shè)計(jì)模式經(jīng)典之代理模式
- JavaScript設(shè)計(jì)模式之緩存代理模式原理與簡單用法示例
- js設(shè)計(jì)模式之代理模式及訂閱發(fā)布模式實(shí)例詳解
- JavaScript設(shè)計(jì)模式之代理模式簡單實(shí)例教程
- JavaScript命令模式原理與用法實(shí)例詳解
- JavaScript觀察者模式原理與用法實(shí)例詳解
- JavaScript享元模式原理與用法實(shí)例詳解
- JavaScript裝飾者模式原理與用法實(shí)例詳解
- JavaScript代理模式原理與用法實(shí)例詳解
相關(guān)文章
Javascript DOM的簡介,節(jié)點(diǎn)和獲取元素詳解
下面小編就為大家分享一篇詳談DOM的簡介,節(jié)點(diǎn)和獲取元素,具有非常好的參考價(jià)值,一起跟隨小編過來看看吧,希望對大家有所幫助2021-11-11JS 參數(shù)傳遞的實(shí)際應(yīng)用代碼分析
在項(xiàng)目中,有一個(gè)Ajax加載的區(qū)域,是一個(gè)Div標(biāo)簽,id為msg_box,這個(gè)控制鏈接包含在一個(gè)左側(cè)的導(dǎo)航中,當(dāng)從其他頁面鏈接到這個(gè)頁面時(shí),該JS代碼就失效了。2009-09-09JS使用插件cryptojs進(jìn)行加密解密數(shù)據(jù)實(shí)例
這篇文章主要介紹了JS使用插件cryptojs進(jìn)行加密解密數(shù)據(jù),結(jié)合完整實(shí)例形式分析了javascript基于加密插件實(shí)現(xiàn)加密解密功能的相關(guān)操作技巧,需要的朋友可以參考下2017-05-05JS實(shí)現(xiàn)簡易的圖片拖拽排序?qū)嵗a
這篇文章主要介紹了JS實(shí)現(xiàn)簡易的圖片拖拽排序?qū)嵗a,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06javascript對select標(biāo)簽的控制(option選項(xiàng)/select)
html中的select標(biāo)簽,也是asp.net中的asp:DropDownList控件,接下來介紹javascript對select標(biāo)簽的控制,感興趣的朋友可以了解下,或許本文對你有所幫助2013-01-01