国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專(zhuān)題視頻專(zhuān)題問(wèn)答1問(wèn)答10問(wèn)答100問(wèn)答1000問(wèn)答2000關(guān)鍵字專(zhuān)題1關(guān)鍵字專(zhuān)題50關(guān)鍵字專(zhuān)題500關(guān)鍵字專(zhuān)題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專(zhuān)題關(guān)鍵字專(zhuān)題tag2tag3文章專(zhuān)題文章專(zhuān)題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專(zhuān)題3
問(wèn)答文章1 問(wèn)答文章501 問(wèn)答文章1001 問(wèn)答文章1501 問(wèn)答文章2001 問(wèn)答文章2501 問(wèn)答文章3001 問(wèn)答文章3501 問(wèn)答文章4001 問(wèn)答文章4501 問(wèn)答文章5001 問(wèn)答文章5501 問(wèn)答文章6001 問(wèn)答文章6501 問(wèn)答文章7001 問(wèn)答文章7501 問(wèn)答文章8001 問(wèn)答文章8501 問(wèn)答文章9001 問(wèn)答文章9501
當(dāng)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

JavaScript設(shè)計(jì)模式之單例模式原理與用法實(shí)例分析

來(lái)源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:10:57
文檔

JavaScript設(shè)計(jì)模式之單例模式原理與用法實(shí)例分析

JavaScript設(shè)計(jì)模式之單例模式原理與用法實(shí)例分析:本文實(shí)例講述了JavaScript設(shè)計(jì)模式之單例模式原理與用法。分享給大家供大家參考,具體如下: 單例模式的定義:保證一個(gè)類(lèi)僅有一個(gè)實(shí)例,并提供一個(gè)訪問(wèn)它的全局訪問(wèn)點(diǎn)。 單例模式是一種常用的模式,有些對(duì)象只需要一個(gè),如線程池、全局緩存、瀏覽器中的win
推薦度:
導(dǎo)讀JavaScript設(shè)計(jì)模式之單例模式原理與用法實(shí)例分析:本文實(shí)例講述了JavaScript設(shè)計(jì)模式之單例模式原理與用法。分享給大家供大家參考,具體如下: 單例模式的定義:保證一個(gè)類(lèi)僅有一個(gè)實(shí)例,并提供一個(gè)訪問(wèn)它的全局訪問(wèn)點(diǎn)。 單例模式是一種常用的模式,有些對(duì)象只需要一個(gè),如線程池、全局緩存、瀏覽器中的win

本文實(shí)例講述了JavaScript設(shè)計(jì)模式之單例模式原理與用法。分享給大家供大家參考,具體如下:

單例模式的定義:保證一個(gè)類(lèi)僅有一個(gè)實(shí)例,并提供一個(gè)訪問(wèn)它的全局訪問(wèn)點(diǎn)。

單例模式是一種常用的模式,有些對(duì)象只需要一個(gè),如線程池、全局緩存、瀏覽器中的window對(duì)象等,這時(shí)候可以用到單例模式。

單例模式典型的應(yīng)用場(chǎng)景:?jiǎn)螕舭粹o時(shí),頁(yè)面中會(huì)出現(xiàn)一個(gè)登陸浮窗,而該登錄浮窗是唯一的,無(wú)論單擊多少次按鈕,這個(gè)浮窗都會(huì)被創(chuàng)建一次,則適合用單例模式創(chuàng)建。

全局變量不是單例模式,但在JavaScript開(kāi)發(fā)中,經(jīng)常會(huì)把全局變量當(dāng)成單例來(lái)使用。

使用var a = {};這種方式創(chuàng)建對(duì)象a時(shí),對(duì)象a是獨(dú)一無(wú)二的,若變量a被聲明在全局作用域下,則可以在代碼的任何位置使用這個(gè)變量。這顯然滿(mǎn)足單例模式的兩個(gè)條件。

但是全局變量存在很多問(wèn)題,很容易造成命名空間污染,如上面的var a = {};隨時(shí)有可能被覆蓋。

有必要盡量減少全局變量的使用,即使需要,也應(yīng)該把它的污染降到最低。

降低全局變量帶來(lái)的命名污染的幾種方式:

1) 使用命名空間

適當(dāng)?shù)厥褂妹臻g,并不會(huì)杜絕全局變量,但可以減少全局變量的數(shù)量。

把a(bǔ)和b都定義為namespace的屬性,這樣可以減少變量和全局作用域打交道的機(jī)會(huì):

var namespace = {
 a: function() {
 alert("a");
 },
 b: function() {
 alert("b");
 }
};

動(dòng)態(tài)地創(chuàng)建命名空間:

var obj = {};
obj.namespace = function(name) {
 var tips = name.split('.');
 var cur = obj;
 for (var i in tips) {
 if (!cur[tips[i]])
 cur[tips[i]] = {};
 cur = cur[tips[i]];
 }
};
obj.namespace('name');
obj.namespace('birth.year');
console.dir(obj);

上述代碼等價(jià)于:

var obj = {
 name: {},
 birth: {
 year: {}
 }
};

2) 使用閉包封裝私有變量

var person = (function() {
 var_name = "Alice";
 var _id = 16;
 return {
 getUserInfo: function() {
 return _name + ": " + _id;
 }
 }
})();

使用下劃線來(lái)約定私有變量_name和_age,它們被封裝在閉包產(chǎn)生的作用域中,外部是訪問(wèn)不到這兩個(gè)變量的,這就避免了對(duì)全局的命令污染。

惰性單例模式:

在需要的時(shí)候才創(chuàng)建對(duì)象實(shí)例。

var createBox = (function() {
 var div;
 return function() {
 if (!div) {
 div = document.createElement('div');
 div.innerHTML = '登錄';
 div.style.display = 'none';
 document.body.appendChild(div);
 }
 return div;
 }
})();
document.getElementById('btn').onclick = function() {
 var box = createBox();
 box.style.display = 'block';
};

用變量div來(lái)判斷是否已經(jīng)創(chuàng)建過(guò)浮窗。

通用的惰性單例:

問(wèn)題:上面的惰性單例實(shí)例是違反單一職責(zé)原則的,創(chuàng)建對(duì)象和管理單例的邏輯都放在createBox對(duì)象內(nèi)部。若下次要?jiǎng)?chuàng)建頁(yè)面中唯一的iframe,需要把createBox幾乎照抄一遍。

var createIframe = (function() {
 var iframe;
 return function() {
 if (!iframe) {
 iframe = document.createElement('iframe');
 document.body.appendChild(iframe);
 return iframe;
 }
 return div;
 }
})();

解決:把不變的部分隔離出來(lái),其實(shí),管理單例的邏輯可以完全抽象出來(lái),因?yàn)樗鼈兊倪壿嬍且粯拥模河靡粋€(gè)變量來(lái)標(biāo)記是否創(chuàng)建過(guò)對(duì)象,若是,則在下次直接返回已經(jīng)創(chuàng)建好的對(duì)象。

var createSingle = function(func) {
 var flag;
 return flag || (flag = func.apply(this, arguments));
};
var createBox = function() {
 var div = document.createElement('div');
 div.innerHTML = '登錄';
 div.style.display = 'none';
 document.body.appendChild(div);
 return div;
};
document.getElementById('btn').onclick = function() {
 var box = createBox();
 box.style.display = 'block';
};
var createIframe = createSingle(function() {
 var iframe = document.createElement('iframe');
 document.body.appendChild(iframe);
 return iframe;
});
document.getElementById('btn').onclick = function() {
 var iframe = createIframe();
 iframe.style.display = 'block';
};

單例模式的其他用途:

單例模式的用途遠(yuǎn)不止于創(chuàng)建對(duì)象,比如click事件只需要在第一次渲染頁(yè)面時(shí)綁定一次,顯然運(yùn)用jQuery的one()方法可以實(shí)現(xiàn)。若運(yùn)用createSingle 方法,也很容易實(shí)現(xiàn):

var createSingle = function(func) {
 var flag;
 return flag || (flag = func.apply(this, arguments));
};
var bindEvent = createSingle(function() {
 document.getElementById(‘div').onclick = function() {
 ...
 };
 return true;
});
var render = function() {
 bindEvent();
};
render();
render();
render();

render()函數(shù)與bindEvent()函數(shù)執(zhí)行了3次,但div實(shí)際上只被綁定了一次。

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

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

聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

JavaScript設(shè)計(jì)模式之單例模式原理與用法實(shí)例分析

JavaScript設(shè)計(jì)模式之單例模式原理與用法實(shí)例分析:本文實(shí)例講述了JavaScript設(shè)計(jì)模式之單例模式原理與用法。分享給大家供大家參考,具體如下: 單例模式的定義:保證一個(gè)類(lèi)僅有一個(gè)實(shí)例,并提供一個(gè)訪問(wèn)它的全局訪問(wèn)點(diǎn)。 單例模式是一種常用的模式,有些對(duì)象只需要一個(gè),如線程池、全局緩存、瀏覽器中的win
推薦度:
標(biāo)簽: 實(shí)例 javascript 分析
  • 熱門(mén)焦點(diǎn)

最新推薦

猜你喜歡

熱門(mén)推薦

專(zhuān)題
Top
主站蜘蛛池模板: 欧美人与禽交zozo | 久久久一本 | 一本综合久久国产二区 | 一区在线看 | zozozo欧美人禽交另类视频 | 中文字幕免费观看 | 日韩视频免费看 | 精品在线看| 国产精品久久久久久久久99热 | 国产精品免费观看视频 | 国产 日韩 在线 | 国产精品视频第一区二区三区 | 亚洲国产精品日韩在线 | 91香蕉福利一区二区三区 | 黄色在线观看视频网站 | 国产成人3p视频免费观看 | 欧美日韩高清完整版在线观看免费 | 国产亚洲欧美日韩综合另类 | 亚洲爱爱网站 | 国产成人综合一区精品 | 91久久国产口精品久久久久 | 久久久久久综合成人精品 | 一本久道久久综合 | 在线永久免费观看的毛片 | 久久国产成人精品 | 精品久久久久久久久中文字幕 | 日本亚洲国产精品久久 | 欧美日韩三级在线观看 | 亚洲天码中文字幕第一页 | 国内自拍一区 | 欧美一区二区在线视频 | 在线综合亚洲欧美自拍 | 欧美激情视频一区二区三区 | 精品一区二区三区在线成人 | 一级全黄60分钟免费网站 | 国产亚洲欧美日韩俺去了 | 精品欧美一区二区在线观看 | 亚洲欧美综合图片 | 欧美日视频| 综合欧美日韩 | 亚洲欧美天堂 |