小編給大家分享一下web前端中單例模式的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
寶興ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場(chǎng)景,ssl證書未來(lái)市場(chǎng)廣闊!成為創(chuàng)新互聯(lián)建站的ssl證書銷售渠道,可以享受市場(chǎng)價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!
顧名思義,單例模式中Class的實(shí)例個(gè)數(shù)最多為1。當(dāng)需要一個(gè)對(duì)象去貫穿整個(gè)系統(tǒng)執(zhí)行某些任務(wù)時(shí),單例模式就派上了用場(chǎng)。而除此之外的場(chǎng)景盡量避免單例模式的使用,因?yàn)閱卫J綍?huì)引入全局狀態(tài),而一個(gè)健康的系統(tǒng)應(yīng)該避免引入過(guò)多的全局狀態(tài)。
實(shí)現(xiàn)單例模式需要解決以下幾個(gè)問(wèn)題:
如何確定Class只有一個(gè)實(shí)例?
如何簡(jiǎn)便的訪問(wèn)Class的唯一實(shí)例?
Class如何控制實(shí)例化的過(guò)程?
如何將Class的實(shí)例個(gè)數(shù)限制為1?
我們一般通過(guò)實(shí)現(xiàn)以下兩點(diǎn)來(lái)解決上述問(wèn)題:
隱藏Class的構(gòu)造函數(shù),避免多次實(shí)例化
通過(guò)暴露一個(gè) getInstance() 方法來(lái)創(chuàng)建/獲取唯一實(shí)例
Javascript中單例模式可以通過(guò)以下方式實(shí)現(xiàn):
// 單例構(gòu)造器const FooServiceSingleton = (function () { // 隱藏的Class的構(gòu)造函數(shù) function FooService() {} // 未初始化的單例對(duì)象 let fooService; return { // 創(chuàng)建/獲取單例對(duì)象的函數(shù) getInstance: function () { if (!fooService) { fooService = new FooService(); } return fooService; } }})();
實(shí)現(xiàn)的關(guān)鍵點(diǎn)有:
使用 IIFE創(chuàng)建局部作用域并即時(shí)執(zhí)行;
getInstance()
為一個(gè) 閉包 ,使用閉包保存局部作用域中的單例對(duì)象并返回。
我們可以驗(yàn)證下單例對(duì)象是否創(chuàng)建成功:
const fooService1 = FooServiceSingleton.getInstance(); const fooService2 = FooServiceSingleton.getInstance(); console.log(fooService1 === fooService2); // true
場(chǎng)景例子
定義命名空間和實(shí)現(xiàn)分支型方法
登錄框
vuex 和 redux中的store
優(yōu)點(diǎn)
劃分命名空間,減少全局變量
增強(qiáng)模塊性,把自己的代碼組織在一個(gè)全局變量名下,放在單一位置,便于維護(hù)
且只會(huì)實(shí)例化一次。簡(jiǎn)化了代碼的調(diào)試和維護(hù)
缺點(diǎn)
由于單例模式提供的是一種單點(diǎn)訪問(wèn),所以它有可能導(dǎo)致模塊間的強(qiáng)耦合
從而不利于單元測(cè)試。無(wú)法單獨(dú)測(cè)試一個(gè)調(diào)用了來(lái)自單例的方法的類,而只能把它與那個(gè)單例作為一
個(gè)單元一起測(cè)試。
以上是“web前端中單例模式的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
網(wǎng)站名稱:web前端中單例模式的示例分析
網(wǎng)站URL:http://vcdvsql.cn/article32/pccesc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設(shè)計(jì)公司、網(wǎng)站排名、網(wǎng)站維護(hù)、建站公司、定制網(wǎng)站、網(wǎng)站設(shè)計(jì)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)