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

您的位置:首頁技術文章
文章詳情頁

JavaScript設計模式---單例模式詳解【四種基本形式】

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

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

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

1,單體模式用于創建命名空間,將系列關聯的屬性和方法組織成一個邏輯單元,減少全局變量?!∵壿媶卧械拇a通過單一的變量進行訪問。

2,三個特點: ① 該類只有一個實例;?、?該類自行創建該實例,即在該類內部創建自身的實例對象; ③ 向整個系統公開這個實例接口

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

第一種,最簡單的單體,只被實例化一次 我簡記為json對象

(1)基本結構

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

(2)使用方法與json的使用方法一致:使用點 ' . '的方式訪問

alert(userInfo.getName())

單體模式用來劃分命名空間,并將一群相關的屬性和方法組織到一起的簡單介紹:

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

總結:該種方式可以看出對象的變量值不是動態加載的,而且對象沒有顯示初始化,由此有了第二種單體模式。

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

要求:模擬一個使用ajax從數據庫加載數據的過程

(1)簡單模擬一下ajax過程

//模擬一個Ajax操作 function Ajax() {};//空對象 //靜態函數 模擬作為從數據庫取值 此處值寫死的 Ajax.request=function (url,fn) { //默認永遠回調成功 if(true){ fn('測試值1','測試值2') } }

(2)在最簡單的單體中出現了數據不是動態從數據庫加載的,而且沒有顯示實例化對象,此處使用閉包原理解決上述問題

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

(3)使用該種方式的單體,不用實例化 可以直接返回一個單體 【因為使用userInfo時,直接return一個單體回來】

alert(userInfo.name);

總結:

(1)優點,靈活

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

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

于是在第二種的基礎上進行修改為,

(1)模擬ajax從數據庫加載數據不變

//模擬一個Ajax操作 function Ajax() {} //靜態函數 模擬作為從數據庫取值 Ajax.request=function (url,fn) { //默認永遠回調成功 if(true){ fn('測試值1','測試值2') } }

(2)動態從數據庫加載數據 ,顯示實例化,使用一個函數(Init())封裝產生單體的函數,通過一個私有變量來返回函數(Init())

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

(3)使用 訪問UserInfo對象里面的獲取初始化獲取對象的函數(getInstance())

alert(UserInfo.getInstance().name);

總結:使用惰性單體實質上是通過對產生單體的函數進行再一次封裝(使用函數封裝),再在通過該類提供的唯一接口(getInstance()方法)訪問初始化單體 的函數。

第四種,分支單體

簡單的用處:做Ajax的時候根據不同的瀏覽器獲得不同的XHR。(將瀏覽器之間的差異封裝到動態方法,適用于解決瀏覽器之間的差異。)

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

(1)獲取電腦的分辨率

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

(2)進行分支判斷處理 ,將差異封裝到動態方法中

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

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

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

總結一下,對于分支單體有一個缺點:分支中,單體1和單體2都被創建了,并保存在內存中了,但只用到一個。需要在 計算時間 和 占用內存 兩者中取舍。

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

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩一区二区综合 | 久久激情中文| 久久在线91| 精品国产中文字幕第一页| 国产精品视频首页| 久久av综合| 精品高清久久| 中文字幕在线视频网站| 在线看片国产福利你懂的| 精品国产乱码久久久久久1区2匹| 精品入口麻豆88视频| 国产精品精品| 久久婷婷激情| 久热精品在线| 亚洲综合激情在线| 日本aⅴ免费视频一区二区三区| 久久激情综合网| 精品国产成人| jiujiure精品视频播放| 性色一区二区| 欧美日韩1区| 日本久久综合| 红桃视频国产一区| 日韩欧美中文在线观看| 国产亚洲精品美女久久久久久久久久| 国产极品模特精品一二| 国产成人精品一区二区三区免费| 中文字幕人成乱码在线观看| 美女久久久久| 日韩专区一卡二卡| 国产亚洲字幕| 国产一区二区三区久久久久久久久| av中文资源在线资源免费观看| 亚洲性图久久| 日韩高清一区| 日韩a一区二区| 日韩午夜av| 国产丝袜一区| 四虎884aa成人精品最新| 美国三级日本三级久久99| 国产精品免费99久久久| 丝袜av一区| 日韩精品视频在线看| 成人日韩av| 美女久久一区| 国产精品99久久久久久董美香| 四虎884aa成人精品最新| 亚洲精品视频一二三区| 国产精品二区不卡| 在线看片日韩| 中文字幕在线看片| 日韩精品午夜视频| 亚洲综合国产| 精品一区二区三区中文字幕| 亚洲激精日韩激精欧美精品| 国产极品模特精品一二| 中国女人久久久| 麻豆国产精品777777在线| 欧美91福利在线观看| 国产精品一区高清| 亚洲成av人片一区二区密柚| 日本久久一区| 狠狠干成人综合网| 精品国产乱码| 亚洲精品极品| 亚洲国产专区校园欧美| 国产激情精品一区二区三区| 亚洲尤物在线| 岛国av免费在线观看| 日韩av网站免费在线| 免费视频国产一区| 国产精品超碰| 亚洲天堂日韩在线| 午夜精品成人av| 久久狠狠亚洲综合| 国产二区精品| 麻豆mv在线观看| 国产探花一区| 在线精品国产亚洲| 激情欧美国产欧美| 久久亚洲黄色| 日韩激情啪啪| 亚洲激情国产| 日韩中文视频| 欧美亚洲一区二区三区| 亚洲专区一区| 在线视频观看日韩| 国产高清不卡| 久久99青青| 日韩中文字幕一区二区高清99| 午夜影院一区| 国产精品亚洲综合久久| 亚洲精品免费观看| 蘑菇福利视频一区播放| 91精品一区国产高清在线gif | 欧美日韩伊人| 蜜芽一区二区三区| 亚洲少妇自拍| 91超碰国产精品| 99成人超碰| 新版的欧美在线视频| 嫩草伊人久久精品少妇av杨幂| 日韩欧美中文字幕在线视频| 免费人成黄页网站在线一区二区| 视频一区中文| 欧美丝袜一区| 99久久激情| 久久精品主播| 日韩欧美少妇| аⅴ资源天堂资源库在线| 欧美精品导航| 欧美国产不卡| 麻豆精品久久久| 国产精品极品在线观看| 国产欧美日韩视频在线| 日韩不卡在线观看日韩不卡视频| 国产毛片一区| 国产精品老牛| 美女被久久久| 亚洲va久久| 日本亚洲欧美天堂免费| 亚洲ww精品| 日韩av一区二| 国产乱码精品一区二区三区四区 | 国产精品视频一区视频二区| 一级欧美视频| 四虎国产精品免费久久| 亚洲精品日韩久久| 日韩国产欧美一区二区三区| 久久国产精品免费精品3p| 国产精品1区| 国产aⅴ精品一区二区四区| 久久精品国产久精国产爱| 成人在线观看免费视频| 日韩av免费大片| 欧美亚洲精品在线| 欧美精品一区二区三区精品| 久久蜜桃av| 久久精品卡一| 亚洲欧美日韩一区在线观看| 久久亚洲色图| 日韩1区2区日韩1区2区| 国产精品扒开腿做爽爽爽软件| 美女久久久精品| 日韩欧美视频专区| 激情综合网五月| 蜜桃视频免费观看一区| 欧美亚洲tv| 97精品国产| 欧美高清不卡| 日韩精品福利一区二区三区| 国产精品magnet| 久久视频一区| 综合欧美精品| 久久影视三级福利片| www.51av欧美视频| 影音先锋久久| 国产日韩1区| 国产精品原创| 天堂成人免费av电影一区| 国产精品亚洲综合久久| 美女网站视频一区| 久久国产精品毛片| 欧美亚洲人成在线| 亚洲啊v在线| 免费在线欧美视频| 亚洲人成高清| 超级白嫩亚洲国产第一| 中日韩男男gay无套| 国产精品久久久久77777丨| 国产夫妻在线| 亚洲一二av| 91嫩草亚洲精品| 亚洲三级在线| 97精品国产| 亚洲精品进入| 樱桃视频成人在线观看| 日韩精品一区第一页| 免费在线成人| 亚洲激情另类| 精品国产精品国产偷麻豆| 99在线观看免费视频精品观看| 国产日韩视频| 美女少妇全过程你懂的久久| 国产精选一区| 国产专区一区| 免费看久久久| 视频一区二区三区中文字幕| 精品视频久久| 亚洲人www| 欧美一区二区性| 国产精品夜夜夜| 国产女优一区| 国产精品专区免费| 国产欧美日韩在线观看视频| 欧美日韩国产精品一区二区亚洲| 久久超级碰碰| 免费在线观看不卡| 欧美天堂视频| 国产精品一区高清|