2018-06-13 設(shè)計模式 觀察者

觀察者模式分為兩個對象訂閱者和發(fā)布者,訂閱者可以有多個,原理就是發(fā)布者將訂閱者的對象指針保存下來,如果有消息了需要通知了,那么發(fā)布者遍歷訂閱者的對象,然后分別調(diào)用他們的方法,將值傳過去.

例子:

// 創(chuàng)建發(fā)布者

function Publisher(){

var observice = [] // 發(fā)布者內(nèi)部定義一個屬性,用于存儲訂閱者對象的指針

}

Publisher.prototype.add = function (observice) { // 發(fā)布者定義一個方法向自身的屬性中添加訂閱者

var flag = false

this.observice.map(function (item) {

if (item === observice) {

flag = true

}

})

if (!flag) {

this.observice.push(observice)

}

}

Publisher.prototype.send = function (state) { // 發(fā)布者發(fā)布消息

this.observice.map(function (item) {

item.update(item)

})

return this

}

而對于訂閱者來說,只需要實現(xiàn)update方法即可,例子如下:

function Subscriber(){}

Subscriber.prototype.update = function (event) {}

使用如下:

var p = new?Publisher()

var s1 = new?Subscriber()

s1.update = function () {} // 根據(jù)需要重寫update方法

p.add(s1) // 將s1添加到發(fā)布者的存儲列表中

s1.send('發(fā)布了') // 調(diào)用發(fā)送方法

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末南捂,一起剝皮案震驚了整個濱河市甫菠,隨后出現(xiàn)的幾起案子谅河,更是在濱河造成了極大的恐慌,老刑警劉巖抵拘,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異怠惶,居然都是意外死亡回季,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進店門秕重,熙熙樓的掌柜王于貴愁眉苦臉地迎上來不同,“玉大人,你說我怎么就攤上這事溶耘《眨” “怎么了?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵凳兵,是天一觀的道長百新。 經(jīng)常有香客問我,道長庐扫,這世上最難降的妖魔是什么饭望? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮形庭,結(jié)果婚禮上铅辞,老公的妹妹穿的比我還像新娘。我一直安慰自己萨醒,他們只是感情好斟珊,可當我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著富纸,像睡著了一般囤踩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上晓褪,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天高职,我揣著相機與錄音,去河邊找鬼辞州。 笑死怔锌,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的变过。 我是一名探鬼主播埃元,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼媚狰!你這毒婦竟也來了岛杀?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤崭孤,失蹤者是張志新(化名)和其女友劉穎类嗤,沒想到半個月后糊肠,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡遗锣,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年货裹,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片精偿。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡弧圆,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出笔咽,到底是詐尸還是另有隱情搔预,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布叶组,位于F島的核電站拯田,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏甩十。R本人自食惡果不足惜勿锅,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望枣氧。 院中可真熱鬧溢十,春花似錦、人聲如沸达吞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽酪劫。三九已至吞鸭,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間覆糟,已是汗流浹背刻剥。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留滩字,地道東北人造虏。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像麦箍,于是被迫代替她去往敵國和親漓藕。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,724評論 2 351

推薦閱讀更多精彩內(nèi)容

  • 工廠模式類似于現(xiàn)實生活中的工廠可以產(chǎn)生大量相似的商品挟裂,去做同樣的事情享钞,實現(xiàn)同樣的效果;這時候需要使用工廠模式。簡單...
    舟漁行舟閱讀 7,729評論 2 17
  • 單例模式 適用場景:可能會在場景中使用到對象诀蓉,但只有一個實例栗竖,加載時并不主動創(chuàng)建暑脆,需要時才創(chuàng)建 最常見的單例模式,...
    Obeing閱讀 2,058評論 1 10
  • 面向?qū)ο缶幊?1.創(chuàng)建狐肢,使用函數(shù) var CheckObject = {checkName : function(...
    依米花1993閱讀 386評論 0 0
  • Lua 5.1 參考手冊 by Roberto Ierusalimschy, Luiz Henrique de F...
    蘇黎九歌閱讀 13,770評論 0 38
  • 一夜悄然覆地來添吗,萬戶啟扉映眼白。 盼君何故遲姍姍处坪,落雪依舊喜盈懷。 __...
    秋英煥煥閱讀 439評論 0 2