欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實現(xiàn)單例模式的6種方案匯總

 更新時間:2021年05月19日 09:56:14   作者:粥里有勺糖  
單例模式的定義是保證一個類僅有一個實例,下面這篇文章主要給大家介紹了關(guān)于JS實現(xiàn)單例模式的6種方案,需要的朋友可以參考下

前言

今天在復(fù)習(xí)設(shè)計模式中的-創(chuàng)建型模式,發(fā)現(xiàn)JS實現(xiàn)單例模式的方案有很多種,稍加總結(jié)了一下,列出了如下的6種方式與大家分享

大體上將內(nèi)容分為了ES5(Function)與ES6(Class)實現(xiàn)兩種部分

單例模式的概念

單例模式就是在系統(tǒng)中保存一個實例,就是一個全局變量,在團隊開發(fā)中,為了實現(xiàn)一些相似的功能,比如不同頁面之間的表單驗證,可能需求是不一樣的,但是呢命名可能一樣,這時就會產(chǎn)生沖突,這時候單例模式就能很好的解決這個問題。

  • 一個實例只生產(chǎn)一次
  • 保證一個類僅有一個實例,并提供一個訪問它的全局訪問點

說說它的優(yōu)點:

1,單例模式聲明一個命名空間,它生成一個唯一的全局變量,一個命名空間,可以用聲明對象的方式來聲明:

var mapleTao={ name:"mapleTao",init:function(){console.log(this.name)}};

有木有發(fā)現(xiàn)這個和對象有點類似呢,其實name,init是它的屬性,通過mapleTao.name就獲取它name的值,通過mapleTao.init()就可以調(diào)用init方法,這樣在哎處理多需求頁面,多人開發(fā)時就能很好的解決命名沖突的問題,以及可以更好的維護代碼,更好的控制代碼。

2,單例模式在全局中只聲明一個變量,大家都知道在js中,假設(shè)你寫了一個方法,如 function aa(){},這樣就會在window中生成一個叫aa的變量,當(dāng)實現(xiàn)一個功能時,在代碼封裝中,會創(chuàng)建好多函數(shù),好多function,這樣就會在window中創(chuàng)建好多變量,會占用更多的內(nèi)存單元,全局變量的作用域很廣,在眾多處理函數(shù)中都可能改變,這樣當(dāng)出現(xiàn)bug時不容易快速找到,而通過單例模式創(chuàng)建的對象變量中可以更快速的找到問題,從而解決,這大大減少的問題修復(fù)的時間以及系統(tǒng)加載的時間。

3.在實現(xiàn)同一個功能的地方比通過new新創(chuàng)建對象對內(nèi)存對資源的占用更據(jù)優(yōu)勢。

方式1

利用instanceof判斷是否使用new關(guān)鍵字調(diào)用函數(shù)進行對象的實例化

function User() {
    if (!(this instanceof User)) {
        return
    }
    if (!User._instance) {
        this.name = '無名'
        User._instance = this
    }
    return User._instance
}

const u1 = new User()
const u2 = new User()

console.log(u1===u2);// true

方式2

在函數(shù)上直接添加方法屬性調(diào)用生成實例

function User(){
    this.name = '無名'
}
User.getInstance = function(){
    if(!User._instance){
        User._instance = new User()
    }
    return User._instance
}

const u1 = User.getInstance()
const u2 = User.getInstance()

console.log(u1===u2);

方式3

使用閉包,改進方式2

function User() {
    this.name = '無名'
}
User.getInstance = (function () {
    var instance
    return function () {
        if (!instance) {
            instance = new User()
        }
        return instance
    }
})()

const u1 = User.getInstance()
const u2 = User.getInstance()

console.log(u1 === u2);

方式4

使用包裝對象結(jié)合閉包的形式實現(xiàn)

const User = (function () {
    function _user() {
        this.name = 'xm'
    }
    return function () {
        if (!_user.instance) {
            _user.instance = new _user()
        }
        return _user.instance
    }
})()

const u1 = new User()
const u2 = new User()

console.log(u1 === u2); // true

當(dāng)然這里可以將閉包部分的代碼單獨封裝為一個函數(shù)

在頻繁使用到單例的情況下,推薦使用類似此方法的方案,當(dāng)然內(nèi)部實現(xiàn)可以采用上述任意一種

function SingleWrapper(cons) {
    // 排除非函數(shù)與箭頭函數(shù)
    if (!(cons instanceof Function) || !cons.prototype) {
        throw new Error('不是合法的構(gòu)造函數(shù)')
    }
    var instance
    return function () {
        if (!instance) {
            instance = new cons()
        }
        return instance
    }
}

function User(){
    this.name = 'xm'
}
const SingleUser = SingleWrapper(User)
const u1 = new SingleUser()
const u2 = new SingleUser()
console.log(u1 === u2);

方式5

在構(gòu)造函數(shù)中利用new.target判斷是否使用new關(guān)鍵字

class User{
    constructor(){
        if(new.target !== User){
            return
        }
        if(!User._instance){
            this.name = 'xm'
            User._instance = this
        }
        return User._instance
    }
}

const u1 = new User()
const u2 = new User()
console.log(u1 === u2);

方式6

使用static靜態(tài)方法

class User {
    constructor() {
        this.name = 'xm'
    }
    static getInstance() {
        if (!User._instance) {
            User._instance = new User()
        }
        return User._instance
    }
}


const u1 = User.getInstance()
const u2 = User.getInstance()

console.log(u1 === u2);

總結(jié)

到此這篇關(guān)于JS實現(xiàn)單例模式的文章就介紹到這了,更多相關(guān)JS單例模式內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • JS中使用變量保存arguments對象的方法

    JS中使用變量保存arguments對象的方法

    這篇文章主要介紹了JS中使用變量保存arguments對象的方法的相關(guān)資料,非常不錯具有參考借鑒價值,需要的朋友可以參考下
    2016-06-06
  • 關(guān)于加快微信小程序開發(fā)的一些小建議

    關(guān)于加快微信小程序開發(fā)的一些小建議

    微信小程序是一種全新的連接用戶與服務(wù)的方式,下面這篇文章主要給大家介紹了關(guān)于加快微信小程序開發(fā)的一些小建議,需要的朋友可以參考下
    2021-05-05
  • JS中==、===你分清楚了嗎

    JS中==、===你分清楚了嗎

    這篇文章主要介紹了JS中==、===你分清楚了嗎,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • jquery 實現(xiàn)上下滾動效果示例代碼

    jquery 實現(xiàn)上下滾動效果示例代碼

    上下滾動的效果,不用說,大家都有看到過,本文為大家介紹下使用jquery實現(xiàn)上下滾動效果,感興趣的朋友可以參考下,希望對大家有所幫助
    2013-08-08
  • 原生js實現(xiàn)圖片輪播特效

    原生js實現(xiàn)圖片輪播特效

    這篇文章主要介紹了原生js實現(xiàn)圖片輪播特效,適合用于商品展示,實現(xiàn)最簡單的廣告輪播效果,感興趣的小伙伴們可以參考一下
    2015-12-12
  • JavaScript設(shè)計模式之門面模式原理與實現(xiàn)方法分析

    JavaScript設(shè)計模式之門面模式原理與實現(xiàn)方法分析

    這篇文章主要介紹了JavaScript設(shè)計模式之門面模式原理與實現(xiàn)方法,結(jié)合實例形式分析了門面模式的原理、實現(xiàn)方法及操作注意事項,需要的朋友可以參考下
    2020-03-03
  • js識別不同瀏覽器基于userAgent做判斷

    js識別不同瀏覽器基于userAgent做判斷

    本節(jié)主要介紹了js識別不同瀏覽器依據(jù)是userAgent,需要的朋友可以參考下
    2014-07-07
  • 微信小程序批量監(jiān)聽輸入框?qū)Π粹o樣式進行控制的實現(xiàn)代碼

    微信小程序批量監(jiān)聽輸入框?qū)Π粹o樣式進行控制的實現(xiàn)代碼

    這篇文章主要介紹了小程序批量監(jiān)聽輸入框?qū)Π粹o樣式進行控制的實現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-10-10
  • web前端開發(fā)也需要日志

    web前端開發(fā)也需要日志

    web前端開發(fā)過程中調(diào)試是一個不可避免的過程,我們有眾多的瀏覽器可供選擇,但是如果您要調(diào)試的平臺瀏覽器不是那么先進呢
    2010-12-12
  • 讓mocha支持ES6模塊的方法實現(xiàn)

    讓mocha支持ES6模塊的方法實現(xiàn)

    這篇文章主要介紹了讓mocha支持ES6模塊的方法實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01

最新評論