日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

JavaScript設(shè)計(jì)模式---單例模式詳解【四種基本形式】

瀏覽:120日期:2023-10-26 14:52:46

本文實(shí)例講述了JavaScript設(shè)計(jì)模式---單例模式.分享給大家供大家參考,具體如下:

單例模式也稱為單體模式,其中:

1,單體模式用于創(chuàng)建命名空間,將系列關(guān)聯(lián)的屬性和方法組織成一個(gè)邏輯單元,減少全局變量?!∵壿媶卧械拇a通過(guò)單一的變量進(jìn)行訪問(wèn)。

2,三個(gè)特點(diǎn):?、?該類只有一個(gè)實(shí)例;?、?該類自行創(chuàng)建該實(shí)例,即在該類內(nèi)部創(chuàng)建自身的實(shí)例對(duì)象;?、?向整個(gè)系統(tǒng)公開(kāi)這個(gè)實(shí)例接口

3,單體模式有四種基本形式:

第一種,最簡(jiǎn)單的單體,只被實(shí)例化一次 我簡(jiǎn)記為json對(duì)象

(1)基本結(jié)構(gòu)

var userInfo={//已經(jīng)自行被實(shí)例化 其實(shí)是一json對(duì)象 name:'測(cè)試名稱', dept:'測(cè)試PD', code:'測(cè)試PD001', getName:function () { return '測(cè)試' } };

(2)使用方法與json的使用方法一致:使用點(diǎn) ' . '的方式訪問(wèn)

alert(userInfo.getName())

單體模式用來(lái)劃分命名空間,并將一群相關(guān)的屬性和方法組織到一起的簡(jiǎn)單介紹:

var comm={};//一個(gè)空對(duì)象 comm.userInfo={//空對(duì)象下的第一個(gè)命名空間 name:'命名空間1下的', code:'001' } comm.funcInfo={//空對(duì)象下的第二個(gè)命名空間 funcName:'命名空間2下的', code:'002' }

總結(jié):該種方式可以看出對(duì)象的變量值不是動(dòng)態(tài)加載的,而且對(duì)象沒(méi)有顯示初始化,由此有了第二種單體模式。

第二種,具有局部變量的單體

要求:模擬一個(gè)使用ajax從數(shù)據(jù)庫(kù)加載數(shù)據(jù)的過(guò)程

(1)簡(jiǎn)單模擬一下ajax過(guò)程

//模擬一個(gè)Ajax操作 function Ajax() {};//空對(duì)象 //靜態(tài)函數(shù) 模擬作為從數(shù)據(jù)庫(kù)取值 此處值寫(xiě)死的 Ajax.request=function (url,fn) { //默認(rèn)永遠(yuǎn)回調(diào)成功 if(true){ fn('測(cè)試值1','測(cè)試值2') } }

(2)在最簡(jiǎn)單的單體中出現(xiàn)了數(shù)據(jù)不是動(dòng)態(tài)從數(shù)據(jù)庫(kù)加載的,而且沒(méi)有顯示實(shí)例化對(duì)象,此處使用閉包原理解決上述問(wèn)題

//使用閉包的原理解決:動(dòng)態(tài)從數(shù)據(jù)庫(kù)加載數(shù)據(jù) ,顯示實(shí)例化 var userInfo=(function () { //(1)利用閉包使單體有自己的私有局部變量 var name=''; var code=''; //(2)利用ajax訪問(wèn)數(shù)據(jù)庫(kù)取到數(shù)據(jù) Ajax.request('url',function (n,c) {//由于模擬的ajax中只是簡(jiǎn)單傳遞參數(shù),所以第一個(gè)參數(shù)可以任意 name=n; code=c; }) //(3)單體實(shí)現(xiàn)私有變量的賦值 return { name:name, code:code } })()

(3)使用該種方式的單體,不用實(shí)例化 可以直接返回一個(gè)單體 【因?yàn)槭褂胾serInfo時(shí),直接return一個(gè)單體回來(lái)】

alert(userInfo.name);

總結(jié):

(1)優(yōu)點(diǎn),靈活

(2)弊端:return 單體數(shù)據(jù)量比較大時(shí),都需要從數(shù)據(jù)庫(kù)取數(shù)據(jù),每次加載都要執(zhí)行,會(huì)影響程序性能。由于該種方式每次加載都要直接執(zhí)行,return單體數(shù)據(jù)量大時(shí)會(huì)影響呈現(xiàn)的性能,于是有了第三種單體模式。

第三種,惰性單體 提供的解決方案為:調(diào)方法時(shí)才實(shí)例化單體,而不是加載時(shí)就執(zhí)行。

于是在第二種的基礎(chǔ)上進(jìn)行修改為,

(1)模擬ajax從數(shù)據(jù)庫(kù)加載數(shù)據(jù)不變

//模擬一個(gè)Ajax操作 function Ajax() {} //靜態(tài)函數(shù) 模擬作為從數(shù)據(jù)庫(kù)取值 Ajax.request=function (url,fn) { //默認(rèn)永遠(yuǎn)回調(diào)成功 if(true){ fn('測(cè)試值1','測(cè)試值2') } }

(2)動(dòng)態(tài)從數(shù)據(jù)庫(kù)加載數(shù)據(jù) ,顯示實(shí)例化,使用一個(gè)函數(shù)(Init())封裝產(chǎn)生單體的函數(shù),通過(guò)一個(gè)私有變量來(lái)返回函數(shù)(Init())

//使用閉包的原理解決:動(dòng)態(tài)從數(shù)據(jù)庫(kù)加載數(shù)據(jù) ,顯示實(shí)例化 var UserInfo=(function () { var userInfo='';//私有變量 function Init() {//在產(chǎn)生單體方式為包裹一層初始化函數(shù) //利用閉包使單體有自己的私有局部變量 var name=''; var code=''; //利用ajax訪問(wèn)數(shù)據(jù)庫(kù)取到數(shù)據(jù) Ajax.request('url',function (n,c) {name=n;code=c; }) //單體 return {name:name,code:code, } } return {//此時(shí)開(kāi)始調(diào)用初始化函數(shù)實(shí)現(xiàn)單體的產(chǎn)生 getInstance:function () {if(userInfo){//userInfo=''為false return userInfo;}else { userInfo=Init(); return userInfo;} } } })()

(3)使用 訪問(wèn)UserInfo對(duì)象里面的獲取初始化獲取對(duì)象的函數(shù)(getInstance())

alert(UserInfo.getInstance().name);

總結(jié):使用惰性單體實(shí)質(zhì)上是通過(guò)對(duì)產(chǎn)生單體的函數(shù)進(jìn)行再一次封裝(使用函數(shù)封裝),再在通過(guò)該類提供的唯一接口(getInstance()方法)訪問(wèn)初始化單體 的函數(shù)。

第四種,分支單體

簡(jiǎn)單的用處:做Ajax的時(shí)候根據(jù)不同的瀏覽器獲得不同的XHR。(將瀏覽器之間的差異封裝到動(dòng)態(tài)方法,適用于解決瀏覽器之間的差異。)

比如下面一個(gè)簡(jiǎn)單的例子:在電腦不同分辨率的情況下初始化不一樣的界面。(這里只是彈窗顯示而已)

(1)獲取電腦的分辨率

//得到機(jī)器的分辨率 var screenWidth=window.screen.width;//width var screenHeight=window.screen.height;//height

(2)進(jìn)行分支判斷處理 ,將差異封裝到動(dòng)態(tài)方法中

var portalInfo=(function () { //單體 var $1280_1024={info:’1,2,3,5’}//單體1 var $1366_768={info:’4,2,1,2’}//單體2 //動(dòng)態(tài)圖選擇瀏覽器的差異結(jié)果(這里是分辨率) if(screenWidth==1280){ return $1280_1024;//返回單體進(jìn)行初始化 }else if(screenWidth==1366){ return $1366_768;//返回單體進(jìn)行初始化 }else { throw new Error('請(qǐng)檢查你當(dāng)前的電腦分辨率') } })();

(3)使用 ,獲取最終的結(jié)果

alert(portalInfo.info)//我的結(jié)果為4,2,1,2 這是由于我的電腦的分辨率為1366*768

總結(jié)一下,對(duì)于分支單體有一個(gè)缺點(diǎn):分支中,單體1和單體2都被創(chuàng)建了,并保存在內(nèi)存中了,但只用到一個(gè)。需要在 計(jì)算時(shí)間 和 占用內(nèi)存 兩者中取舍。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T(mén)教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
精品亚洲免a| 在线一区av| 91视频一区| 亚洲日本网址| 超碰在线99| 久久av偷拍| 国产精品一二| 亚洲综合电影| 亚洲午夜电影| 九色porny丨国产首页在线| 欧美成a人国产精品高清乱码在线观看片在线观看久 | 欧美中文字幕一区二区| 激情五月色综合国产精品| 丝瓜av网站精品一区二区 | 日韩av网站在线观看| 日本特黄久久久高潮| 高清久久精品| 中文字幕一区二区三区在线视频| 国产精品一区高清| 久久亚洲专区| 狂野欧美性猛交xxxx| 久久91导航| 青青国产91久久久久久| 激情自拍一区| 国产偷自视频区视频一区二区| 另类专区亚洲| 欧美三级精品| 日韩欧美1区| 伊人久久视频| 亚洲精品免费观看| 免费观看亚洲| 九一成人免费视频| 日韩制服丝袜先锋影音| 久久国产电影| 欧美日韩中出| 日韩国产一区二区| 亚洲综合电影一区二区三区| 欧美激情久久久久久久久久久| 亚洲激情五月| 国产精品久久久久久久久久齐齐| 成人啊v在线| 亚洲精品极品| 美女少妇全过程你懂的久久| 精品黄色一级片| 伊人久久一区| 性色av一区二区怡红| 国产亚洲电影| 免费高清在线一区| 你懂的国产精品永久在线| 91精品一区| 亚洲午夜在线| 91精品福利观看| 视频在线在亚洲| av不卡在线看| 偷拍欧美精品| 国产成人77亚洲精品www| 国产探花一区在线观看| 国产精品115| 视频国产精品| 亚洲激情婷婷| 色综合www| 国产欧美视频在线| 国产字幕视频一区二区| 国产精品欧美一区二区三区不卡| 久久精品97| 成人亚洲精品| 免费美女久久99| 国产精品亚洲欧美日韩一区在线 | 亚洲深夜av| 国内一区二区三区| 欧美韩一区二区| 98精品久久久久久久| 日韩一区自拍| 99视频一区| 免费精品视频在线| 亚洲免费专区| 蜜臀久久久久久久| 免费欧美在线视频| 国产日韩三级| 日韩国产高清在线| 精品国产不卡一区二区| 蜜桃视频欧美| 97精品国产| 99久久婷婷这里只有精品| 免费久久久久久久久| 中文字幕高清在线播放| 久久精品官网| 国产精品美女| 国产精品视频一区二区三区| 亚洲涩涩av| 欧美天堂一区| 免费在线亚洲欧美| 免费一级欧美片在线观看网站| 久久99青青| 日韩在线观看一区二区| 98精品久久久久久久| 国产精品88久久久久久| 日韩av一区二区在线影视| 成人日韩在线观看| 在线观看亚洲精品福利片| 国产精品亚洲综合色区韩国| 国产一区亚洲| 国产精品v亚洲精品v日韩精品| 中文不卡在线| 久久久久久网| 国产一区二区三区探花| 欧美日韩1区| 亚洲狼人精品一区二区三区| 最新亚洲激情| 免费日韩av| 亚洲2区在线| 亚洲精品看片| 国产精品中文字幕制服诱惑| 国产欧美综合一区二区三区| 午夜电影一区| 国产视频一区二| 久久中文在线| 伊人久久国产| 91精品99| 日韩精品第一| 日韩国产91| 日韩av一区二区在线影视| 欧美日本精品| 国产一区二区亚洲| 欧美精选一区二区三区| 午夜亚洲一区| 日韩欧美2区| 精品网站999| 亚洲精品在线观看91| 四虎在线精品| 麻豆免费精品视频| 日韩深夜视频| 国产亚洲亚洲| 久久久国产精品网站| 免费在线成人| 视频一区二区三区中文字幕| 美日韩一区二区三区| 免费看久久久| 一区在线免费| 亚洲一区不卡| 在线午夜精品| 日韩欧美2区| 精品久久97| 亚洲人成网77777色在线播放 | 精品一区二区三区的国产在线观看| 久久婷婷亚洲| 久久免费精品| 国产 日韩 欧美一区| 日韩福利在线观看| 成人一二三区| 91看片一区| caoporn视频在线| 欧美中文一区| 国产欧美88| 免费亚洲婷婷| 国产日产高清欧美一区二区三区 | 97人人精品| 精品一区二区三区免费看 | 亚洲欧美久久精品| 不卡在线一区| 亚洲一区区二区| 鲁大师影院一区二区三区| 久久成人精品| 亚洲一区欧美| 国产探花在线精品一区二区| 久久国产精品亚洲77777| 亚洲精品一级二级| 色88888久久久久久影院| 99成人在线视频| www成人在线视频| 亚洲成av在线| 欧美a在线观看| 欧美国产极品| 久久福利在线| 久久亚洲国产精品尤物| 久久中文在线| 国产91精品对白在线播放| 色爱av综合网| 久久av一区| 亚洲久久一区| 国产精品蜜月aⅴ在线| 国产精品久久久久久久免费软件 | 日本午夜精品| 欧美激情综合| 国产91在线精品| 日韩不卡在线| 少妇高潮一区二区三区99| 日韩av字幕| av资源新版天堂在线| 亚洲午夜视频| 亚洲一二三区视频| 国产一区二区三区亚洲| 欧美日韩国产高清电影| 亚洲另类av| 国精品产品一区| 国产精品日韩久久久| 国产乱论精品| 波多野结衣一区| 国产精品天堂蜜av在线播放| 精品中文字幕一区二区三区|