亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript設(shè)計模式之中介者模式Mediator

 更新時間:2014年12月30日 17:12:43   投稿:hebedich  
這篇文章主要介紹了javascript設(shè)計模式之中介者模式Mediator,需要的朋友可以參考下

一,總體概要

1,筆者淺談

我們從日常的生活中打個簡單的比方,我們?nèi)シ课葜薪樽夥?,房屋中介人在租房者和房東出租者之間形成一條中介。租房者并不關(guān)心他租誰的房。房東出租者也不關(guān)心他租給誰。因為有中介的存在,這場交易才變得如此方便。

在軟件的開發(fā)過程中,勢必會碰到這樣一種情況,多個類或多個子系統(tǒng)相互交互,而且交互很繁瑣,導(dǎo)致每個類都必須知道他需要交互的類,這樣它們的耦合會顯得異常厲害。牽一發(fā)而動全身,后果很嚴(yán)重,大熊很生氣!~~~~(>_<)~~~~

好了,既然問題提出來了,那有請我們這期的主角------中介者模式出場吧

中介者的功能就是封裝對象之間的交互。如果一個對象的操作會引起其他相關(guān)對象的變化,而這個對象又不希望自己來處理這些關(guān)系,那么就可以去找中介者,讓它來處理這些麻煩的關(guān)系??聪旅娴男±樱?/p>

復(fù)制代碼 代碼如下:

var Participant = function(name) {
    this.name = name;
    this.chatroom = null;
};
Participant.prototype = {
    send: function(message, to) {
        this.chatroom.send(message, this, to);
    },
    receive: function(message, from) {
        log.add(from.name + " to " + this.name + ": " + message);
    }
};
var Chatroom = function() {
    var participants = {};
    return {
        register: function(participant) {
            participants[participant.name] = participant;
            participant.chatroom = this;
        },
        send: function(message, from, to) {
            if (to) {                  
                to.receive(message, from);   
            } else {                    
                for (key in participants) {  
                    if (participants[key] !== from) {
                        participants[key].receive(message, from);
                    }
                }
            }
        }
    };
};
var log = (function() {
    var log = "";
    return {
        add: function(msg) { log += msg + "\n"; },
        show: function() { alert(log); log = ""; }
    }
})();
function run() {
    var yoko = new Participant("Yoko");
    var john = new Participant("John");
    var paul = new Participant("Paul");
    var ringo = new Participant("Ringo");
    var chatroom = new Chatroom();
    chatroom.register(yoko);
    chatroom.register(john);
    chatroom.register(paul);
    chatroom.register(ringo);
    yoko.send("All you need is love.");
    yoko.send("I love you John.");
    john.send("Hey, no need to broadcast", yoko);
    paul.send("Ha, I heard that!");
    ringo.send("Paul, what do you think?", paul);
    log.show();
}

在示例代碼中我們有四個參與者,加入聊天會話通過注冊一個聊天室(中介)。每個參與者的參與對象的代表。參與者相互發(fā)送消息和聊天室的處理路由。

這里的聊天室對象就起到了中介的作用,協(xié)調(diào)其他的對象,進行合理的組織,降低耦合。

二,源碼案例參考

我們應(yīng)該很熟悉MVC三層模型實體模型(Model)、視圖表現(xiàn)層(View)還有控制層(Control/Mediator)。

控制層便是位于表現(xiàn)層與模型層之間的中介者?;\統(tǒng)地說MVC也算是中介者模式在框架設(shè)計中的一個應(yīng)用。

三,案例引入

復(fù)制代碼 代碼如下:

function Player(name) {
    this.points = 0;
    this.name = name;
}
Player.prototype.play = function () {
    this.points += 1;
    mediator.played();
};
var scoreboard = {
    element:document.getElementById('results'),
    update:function (score) {
        var i, msg = '';
        for (i in score) {
            if (score.hasOwnProperty(i)) {
                msg += '<p><strong>' + i + '<\/strong>: ';
                msg += score[i];
                msg += '<\/p>';
            }
        }
        this.element.innerHTML = msg;
    }
};
var mediator = {
    players:{},
    setup:function () {
        var players = this.players;
        players.home = new Player('Home');
        players.guest = new Player('Guest');
    },
    played:function () {
        var players = this.players,
                score = {
                    Home:players.home.points,
                    Guest:players.guest.points
                };
        scoreboard.update(score);
    },
    keypress:function (e) {
        e = e || window.event;
        if (e.which === 49) {
            mediator.players.home.play();
            return;
        }
        if (e.which === 48) {
            mediator.players.guest.play();
            return;
        }
    }
};
mediator.setup();
window.onkeypress = mediator.keypress;
setTimeout(function () {
    window.onkeypress = null;
    console.log('Game over!');
}, 30000);

四,總結(jié)一下

Why Mediator ?

各個對象之間的交互操作非常多,每個對象的行為操作都依賴彼此對方,修改一個對象的行為,同時會涉及到修改很多其他對象的行為,

如果使用Mediator模式,可以使各個對象間的耦合松散,只需關(guān)心和 Mediator的關(guān)系,使多對多的關(guān)系變成了一對多的關(guān)系,

可以降低系統(tǒng)的復(fù)雜性,提高可修改擴展性。

使用中介者模式的場合

1.一組定義良好的對象,現(xiàn)在要進行復(fù)雜的通信。

2.定制一個分布在多個類中的行為,而又不想生成太多的子類。

可以看出,中介對象主要是用來封裝行為的,行為的參與者就是那些對象,但是通過中介者,這些對象不用相互知道。(迪米特法則的具體實現(xiàn))

使用中介者模式的優(yōu)點:

1.降低了系統(tǒng)對象之間的耦合性,使得對象易于獨立的被復(fù)用。

2.提高系統(tǒng)的靈活性,使得系統(tǒng)易于擴展和維護。

使用中介者模式的缺點:

中介者模式的缺點是顯而易見的,因為這個“中介“承擔(dān)了較多的責(zé)任,所以一旦這個中介對象出現(xiàn)了問題,那么整個系統(tǒng)就會受到重大的影響。

相關(guān)文章

最新評論