手寫發(fā)布訂閱

const eventHub = {
  map: {
    // click: [f1 , f2]
  },
  on: (name, fn)=>{
    eventHub.map[name] = eventHub.map[name] || []
    eventHub.map[name].push(fn)
  },
  emit: (name, data)=>{
    const q = eventHub.map[name]
    if(!q) return
    q.map(f => f.call(null, data))
    return undefined
  },  
  off: (name, fn)=>{
    const q = eventHub.map[name]
    if(!q){ return }
    const index = q.indexOf(fn)
    if(index < 0) { return }
    q.splice(index, 1)
  }
}

eventHub.on('click', console.log)
eventHub.on('click', console.error)

setTimeout(()=>{
  eventHub.emit('click', 'frank')
},3000)

用class實現:

class EventHub {
  map = {}
  on(name, fn) {
    this.map[name] = this.map[name] || []
    this.map[name].push(fn)
  }
  emit(name, data) {
    const fnList = this.map[name] || []
    fnList.forEach(fn => fn.call(undefined, data))
  }
  off(name, fn) {
    const fnList = this.map[name] || []
    const index = fnList.indexOf(fn)
    if(index < 0) return
    fnList.splice(index, 1)
  }
}
// 使用
const e = new EventHub()
e.on('click', (name)=>{
  console.log('hi '+ name)
})
e.on('click', (name)=>{
  console.log('hello '+ name)
})
setTimeout(()=>{
  e.emit('click', 'frank')
},3000)
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末羞海,一起剝皮案震驚了整個濱河市玄呛,隨后出現的幾起案子乖坠,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡邪狞,警方通過查閱死者的電腦和手機嵌溢,發(fā)現死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進店門眯牧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人赖草,你說我怎么就攤上這事学少。” “怎么了秧骑?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵版确,是天一觀的道長。 經常有香客問我乎折,道長绒疗,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任骂澄,我火速辦了婚禮吓蘑,結果婚禮上,老公的妹妹穿的比我還像新娘坟冲。我一直安慰自己磨镶,他們只是感情好,可當我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布健提。 她就那樣靜靜地躺著琳猫,像睡著了一般。 火紅的嫁衣襯著肌膚如雪私痹。 梳的紋絲不亂的頭發(fā)上脐嫂,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天,我揣著相機與錄音紊遵,去河邊找鬼账千。 笑死,一個胖子當著我的面吹牛暗膜,可吹牛的內容都是我干的匀奏。 我是一名探鬼主播,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼桦山,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了醋旦?” 一聲冷哼從身側響起恒水,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎饲齐,沒想到半個月后钉凌,有當地人在樹林里發(fā)現了一具尸體,經...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡捂人,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年御雕,在試婚紗的時候發(fā)現自己被綠了矢沿。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡酸纲,死狀恐怖捣鲸,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情闽坡,我是刑警寧澤栽惶,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站疾嗅,受9級特大地震影響外厂,放射性物質發(fā)生泄漏。R本人自食惡果不足惜代承,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一汁蝶、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧论悴,春花似錦掖棉、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至玖像,卻和暖如春紫谷,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背捐寥。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工笤昨, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人握恳。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓瞒窒,卻偏偏與公主長得像,于是被迫代替她去往敵國和親乡洼。 傳聞我的和親對象是個殘疾皇子崇裁,可洞房花燭夜當晚...
    茶點故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內容