javascript觀察者模式

javascript觀察者模式學(xué)習(xí)筆記

原文地址

首先是觀察者模式代碼


// eventProxy.js
'use strict';
const eventProxy = {
  onObj: {},
  oneObj: {},
  on: function(key, fn) {
    if(this.onObj[key] === undefined) {
      this.onObj[key] = [];
    }

    this.onObj[key].push(fn);
  },
  one: function(key, fn) {
    if(this.oneObj[key] === undefined) {
      this.oneObj[key] = [];
    }

    this.oneObj[key].push(fn);
  },
  off: function(key) {
    this.onObj[key] = [];
    this.oneObj[key] = [];
  },
  trigger: function() {
    let key, args;
    if(arguments.length == 0) {
      return false;
    }
    key = arguments[0];
    args = [].concat(Array.prototype.slice.call(arguments, 1));

    if(this.onObj[key] !== undefined
      && this.onObj[key].length > 0) {
      for(let i in this.onObj[key]) {
        this.onObj[key][i].apply(null, args);
      }
    }
    if(this.oneObj[key] !== undefined
      && this.oneObj[key].length > 0) {
      for(let i in this.oneObj[key]) {
        this.oneObj[key][i].apply(null, args);
        this.oneObj[key][i] = undefined;
      }
      this.oneObj[key] = [];
    }
  }
};

export default eventProxy;

在觀察著模式的運(yùn)用當(dāng)中。react組件間的通信會(huì)變得異常簡(jiǎn)單呛伴,而且可以減少組件間的耦合。


import eventProxy from '../eventProxy'

class Parent extends Component{
  render() {
    return (
      <div>
        <Child_1/>
        <Child_2/>
      </div>
    );
  }
}
// componentDidUpdate 與 render 方法與上例一致
class Child_1 extends Component{
  componentDidMount() {
    setTimeout(() => {
      // 發(fā)布 msg 事件
      eventProxy.trigger('msg', 'end');
    }, 1000);
  }
}
// componentDidUpdate 方法與上例一致
class Child_2 extends Component{
  state = {
    msg: 'start'
  };

  componentDidMount() {
    // 監(jiān)聽 msg 事件
    eventProxy.on('msg', (msg) => {
      this.setState({
        msg
      });
    });
  }

  render() {
    return <div>
      <p>child_2 component: {this.state.msg}</p>
      <Child_2_1 />
    </div>
  }
}


最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末猎拨,一起剝皮案震驚了整個(gè)濱河市搁凸,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌睦焕,老刑警劉巖藐握,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件靴拱,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡猾普,警方通過查閱死者的電腦和手機(jī)袜炕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來初家,“玉大人偎窘,你說我怎么就攤上這事×镌冢” “怎么了陌知?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長掖肋。 經(jīng)常有香客問我仆葡,道長,這世上最難降的妖魔是什么志笼? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任沿盅,我火速辦了婚禮,結(jié)果婚禮上纫溃,老公的妹妹穿的比我還像新娘腰涧。我一直安慰自己,他們只是感情好皇耗,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布南窗。 她就那樣靜靜地躺著,像睡著了一般郎楼。 火紅的嫁衣襯著肌膚如雪万伤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天呜袁,我揣著相機(jī)與錄音敌买,去河邊找鬼。 笑死阶界,一個(gè)胖子當(dāng)著我的面吹牛虹钮,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播膘融,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼芙粱,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了氧映?” 一聲冷哼從身側(cè)響起春畔,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后律姨,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體振峻,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年择份,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了扣孟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡荣赶,死狀恐怖凤价,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情讯壶,我是刑警寧澤料仗,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站伏蚊,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏格粪。R本人自食惡果不足惜躏吊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望帐萎。 院中可真熱鬧比伏,春花似錦、人聲如沸疆导。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽澈段。三九已至悠菜,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間败富,已是汗流浹背悔醋。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留兽叮,地道東北人芬骄。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓,卻偏偏與公主長得像鹦聪,于是被迫代替她去往敵國和親账阻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

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

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,527評(píng)論 25 707
  • 簡(jiǎn)單理解邏輯: A發(fā)布一個(gè)消息 ,如果B泽本,C淘太,D都訂閱了這個(gè)事件,則會(huì)將所有訂閱著訂閱的消息依此執(zhí)行。 常見的使用...
    麥子_FE閱讀 230評(píng)論 0 0
  • 開水在受涼 酒香在醞釀 智齒在生長 人在臥鋪上搖搖晃晃 我說我喜歡慢時(shí)光 幸福就與我捉迷藏 2016.6.11
    夾餡鍋鍋閱讀 118評(píng)論 0 0
  • 生命猶如星空下的繁星,密密麻麻的點(diǎn)綴漆黑的夜空造成,然而不管它是無窮無盡的數(shù)量显熏,還是無止境的輪轉(zhuǎn),生命對(duì)于每個(gè)人都只有...
    雄雞小建閱讀 202評(píng)論 1 2
  • 一些定義 數(shù)據(jù)庫(database):保存有組織的數(shù)據(jù)的容器晒屎; 數(shù)據(jù)庫軟件:DBMS(數(shù)據(jù)庫管理系統(tǒng))喘蟆; 數(shù)據(jù)庫是...
    olivia_ong閱讀 628評(píng)論 0 0