成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

單例模式之es3與es6雙版本(設(shè)計(jì)模式)

岳光 / 3430人閱讀

摘要:單例模式是一種重要的設(shè)計(jì)模式,有些對象我們只需要創(chuàng)建一個,比如瀏覽器的對象,模態(tài)對話框。普通類負(fù)責(zé)實(shí)現(xiàn)基本功能,代理類管理單例。

定義

保證一個類僅有以一個實(shí)例,僅能被實(shí)例化/創(chuàng)建一次,并提供全局的訪問點(diǎn)。

單例模式是一種重要的設(shè)計(jì)模式,有些對象我們只需要創(chuàng)建一個,比如瀏覽器的window對象,模態(tài)對話框。實(shí)現(xiàn)這種設(shè)計(jì)模式其實(shí)很簡單,最重要的是在創(chuàng)建實(shí)例的時候,用一個標(biāo)記變量判斷實(shí)例是否已經(jīng)創(chuàng)建。

普通青年寫法
function Singleton(name){
    this.name = name;
    this.instance = null;
}
Singleton.prototype.getName = function(){
    console.log("name: " + this.name);
    return this.name;
}
Singleton.getInstance = function(name){
    if(!this.instance){
        this.instance = new Singleton(name);
    }
    return this.instance;
}
var a = Singleton.getInstance("a");
var b = Singleton.getInstance("b");
alert(a === b);

點(diǎn)評:
該寫法不透明,使用者必須知道用Singleton.getInstance獲取單例,而非通過更加通用的方法new xxx方式。

老司機(jī)寫法
var CreateDiv = function(html){
    this.html = html;
    this.init();
}
CreateDiv.prototype.init = function(){
    var div = document.createElement("div");
    div.innerHTML = this.html;
    document.body.appendChild(div);
}
var SingletonDiv = (function(){
    var instance;
    return function(html){
        if(!instance){
            instance = new CreateDiv(html);
        }
        return instance;
    }
})()
var a = SingletonDiv("yyh");
var b = SingletonDiv("yyh1");

點(diǎn)評:
使用代理類+普通的類,使得職責(zé)分明。普通類負(fù)責(zé)實(shí)現(xiàn)基本功能,代理類管理單例。CreateDiv可以直接生產(chǎn)一個實(shí)例,而加上代理,可以實(shí)現(xiàn)單例。有木有一種模塊拼湊的快感,這就實(shí)現(xiàn)了低耦合。

華麗麗的ES6

在ES6中,可以使用static方法代替閉包存儲單例。

靜態(tài)方法的單例模式
class Singleton {
    constructor(name) {
        this.name = name;
    }
    static getInstance(name) {
        if(!Singleton.instance) {
            Singleton.instance = new Singleton(name)
        }
        return Singleton.instance;
    }
    getName() {
        return this.name;
    }
}
const singletonA = Singleton.getInstance("yyh1");
const singletonB = Singleton.getInstance("yyh2");
console.log(singletonA === singletonB);
console.log(singletonA.getName() === singletonB.getName());

點(diǎn)評:ES6的靜態(tài)方法,和閉包一樣能在減少全局變量污染的同時,使標(biāo)記變量更加長久的保存在內(nèi)存中不被回收。

老司機(jī)的新技能(更加通用的實(shí)現(xiàn)方式)
// 負(fù)責(zé)創(chuàng)建DIV的基本功能
class CreateDiv {
    constructor(html) {
        this.html = html;
        this.init();
    }
    init() {
        const div = document.createElement("div");
        div.innerHTML = this.html;
        document.body.appendChild(div);
    }
}
// 負(fù)責(zé)管理單例
class ProxysingletonCreateDiv {
    constructor(htmlStr) {
        return ProxysingletonCreateDiv.getInstance(htmlStr);
    }
    static getInstance(name) {
        if(!ProxysingletonCreateDiv.instance) {
            ProxysingletonCreateDiv.instance = new CreateDiv(name)
        }
        return ProxysingletonCreateDiv.instance;
    }
}
const singletonC = new ProxysingletonCreateDiv("yyh1");
const singletonD = new ProxysingletonCreateDiv("yyh2");
console.log(singletonC === singletonD);
singletonC.init();
singletonD.init();

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/93910.html

相關(guān)文章

  • 面試官問:能否模擬實(shí)現(xiàn)JS的call和apply方法

    摘要:之前寫過兩篇面試官問能否模擬實(shí)現(xiàn)的操作符和面試官問能否模擬實(shí)現(xiàn)的方法其中模擬方法時是使用的和修改指向。但面試官可能問能否不用和來實(shí)現(xiàn)呢。使用模擬實(shí)現(xiàn)的瀏覽器環(huán)境非嚴(yán)格模式方法的屬性是。 之前寫過兩篇《面試官問:能否模擬實(shí)現(xiàn)JS的new操作符》和《面試官問:能否模擬實(shí)現(xiàn)JS的bind方法》 其中模擬bind方法時是使用的call和apply修改this指向。但面試官可能問:能否不用cal...

    wuyangnju 評論0 收藏0
  • ES3/5模擬實(shí)現(xiàn)ES6塊級作用域方式探究

    摘要:其中就包括定義塊級作用域的關(guān)鍵字塊級作用域如何用低版本模擬如何用低版本模擬加強(qiáng)版如何用低版本模擬自調(diào)用函數(shù)版 簡述 在JavaScript編程中,當(dāng)我們使用關(guān)鍵字var時,該變量是在距離最近的函數(shù)內(nèi)部或是在全局詞法環(huán)境中定義的,即函數(shù)作用域。這是JavaScript由來已久的特性,{}并不一定限制變量作用域的模式也困擾了許多從其他語言轉(zhuǎn)向JavaScript的開發(fā)者。隨著前端工程的發(fā)展...

    2bdenny 評論0 收藏0
  • 你不知道的JavaScript(ES6未來)

    摘要:然而,臨近規(guī)范發(fā)布時,有建議提及未來的版本號切換為編年制,比如用同來指代在年末前被定稿的所有版本??偟脕碚f就是版本號不再那么重要了,開始變得更像一個萬古長青的活標(biāo)準(zhǔn)。 你不知道的JS(下卷)ES6與之未來 第一章:ES的今與明 在你想深入這本書之前,你應(yīng)該對(在讀此書時)JavaScript的最近標(biāo)準(zhǔn)掌握熟練,也就是ES5(專業(yè)來說是ES 5.1)。在此,我們決定全方面地談?wù)撽P(guān)于將近的...

    Julylovin 評論0 收藏0
  • 十二大前端工程師讀書清單

    摘要:本文最早為雙十一而作,原標(biāo)題雙大前端工程師讀書清單,以付費(fèi)的形式發(fā)布在上。發(fā)布完本次預(yù)告后,捕捉到了一個友善的吐槽讀書清單也要收費(fèi)。這本書便從的異步編程講起,幫助我們設(shè)計(jì)快速響應(yīng)的網(wǎng)絡(luò)應(yīng)用,而非簡單的頁面。 本文最早為雙十一而作,原標(biāo)題雙 11 大前端工程師讀書清單,以付費(fèi)的形式發(fā)布在 GitChat 上。發(fā)布之后在讀者圈群聊中和讀者進(jìn)行了深入的交流,現(xiàn)免費(fèi)分享到這里,不足之處歡迎指教...

    happen 評論0 收藏0
  • 十二大前端工程師讀書清單

    摘要:本文最早為雙十一而作,原標(biāo)題雙大前端工程師讀書清單,以付費(fèi)的形式發(fā)布在上。發(fā)布完本次預(yù)告后,捕捉到了一個友善的吐槽讀書清單也要收費(fèi)。這本書便從的異步編程講起,幫助我們設(shè)計(jì)快速響應(yīng)的網(wǎng)絡(luò)應(yīng)用,而非簡單的頁面。 本文最早為雙十一而作,原標(biāo)題雙 11 大前端工程師讀書清單,以付費(fèi)的形式發(fā)布在 GitChat 上。發(fā)布之后在讀者圈群聊中和讀者進(jìn)行了深入的交流,現(xiàn)免費(fèi)分享到這里,不足之處歡迎指教...

    余學(xué)文 評論0 收藏0

發(fā)表評論

0條評論

岳光

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<