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

JavaScript中EventBus實現(xiàn)對象之間通信

 更新時間:2020年10月18日 16:56:12   作者:soloplayer  
這篇文章主要介紹了JavaScript中EventBus實現(xiàn)對象之間通信,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

 一、什么是EventBus?

我個人理解:EventBus 可以實現(xiàn)對象之間的通信,當(dāng)數(shù)據(jù)或某些特性發(fā)生改變時,能自動監(jiān)聽事件作出一些改變。還有更多的內(nèi)容可能我還沒有拓寬。怎么實現(xiàn)通信呢?這里通過一個例子可以理解到其中的精髓。

二、一個簡單的例子

add(){
  data+=1;
  render(data);
},
minus(){
  data-=1;
  render(data);
},
multiply(){
  data*=2;
  render(data);
},
divide(){
  data/=2;
  render(data);
},

以上代碼是進行加減乘除的運算,數(shù)據(jù)data改變后,對數(shù)據(jù)data進行渲染,調(diào)用到渲染函數(shù)render();

有沒有覺得這樣很麻煩,代碼重復(fù)非常多,但是想表達(dá)的意思就是一個:data 只要進行更新,就調(diào)用一次渲染函數(shù)render()

問題來了:有沒有辦法簡化呢?只要data一改變,就自動調(diào)用render()函數(shù)

三、代碼演示實例

const eventbus=$({});  // 使用jQuery庫創(chuàng)建了一個eventbus。

let xx = {
  data:{
    n:100,
  }
}

updata(data){
  Object.assign(xx.data,data);  //批量賦值

  eventbus.trigger('updataed:xx.data');  //觸發(fā)事件,事件名為:'updataed:xx.data'
}

/* 調(diào)用jquer封裝的事件監(jiān)聽函數(shù) */
eventbus.on('updataed:xx.data',()=>{
  render(xx.data);
})

/* 改進后的加減乘除函數(shù) */

add(){
  updata({n:xx.data.n+1});
},
minus(){
  updata({n:xx.data.n-1});
},
multiply(){
  updata({n:xx.data.n*2});
},
divide(){
  updata({n:xx.data.n/2});
}

只要一調(diào)用updata()函數(shù),就會使eventbus.trigger('updataed:xx.data')觸發(fā),然后事件監(jiān)聽就會觸發(fā),自動調(diào)用render()函數(shù)進行渲染

四、使用class 封裝+繼承EventBus

class EventBus{
  constructor(){
    this.eventbus=$(window);  //使用jquery將eventbus掛載到全局window上
  }
  on(eventName,fn){
    this.eventbus.on(eventName,fn);
  }
  trigger(eventName){
    this.eventbus.trigger(eventName);
  }
  off(eventName,fn){
    this.eventbus.off(eventName,fn);
  }
}

const eventbus=new EventBus();

eventbus.trigger('updated:xx.data')
eventbus.on('updated:xx.data',()=>{
  render(xx.data);
})
eventbus.off('updated:xx.data')

/* 繼承EventBus */

class module extends EventBus{
  constructor(){
    super();  //必須繼承父類的構(gòu)造函數(shù)constructor
  }
}

module.trigger('updated:xx.data')
module.on('updated:xx.data',()=>{
  render(xx.data);
})
module.off('updated:xx.data')

為何要進行class 封裝和繼承EventBus?

答:為了讓代碼更加格式化,不僅在這里能用到EventBus,在其他地方也能使用上。尤其在模塊化的操作中,封裝+繼承這些就顯得十分的重要。這樣能讓代碼有更好的維護性。其他模塊使用到eventbus時的還能有更多的變樣,可以覆蓋重寫父類方法或者再添加一些方法。

到此這篇關(guān)于JavaScript中EventBus實現(xiàn)對象之間通信的文章就介紹到這了,更多相關(guān)JavaScript EventBus對象通信內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • JS立即執(zhí)行函數(shù)功能與用法分析

    JS立即執(zhí)行函數(shù)功能與用法分析

    這篇文章主要介紹了JS立即執(zhí)行函數(shù)功能與用法,結(jié)合實例形式分析了立即執(zhí)行函數(shù)的相關(guān)概念、定義、使用方法及操作注意事項,需要的朋友可以參考下
    2019-01-01
  • swiper動態(tài)改變滑動內(nèi)容的實現(xiàn)方法

    swiper動態(tài)改變滑動內(nèi)容的實現(xiàn)方法

    假設(shè)當(dāng)前顯示的是1,往左滑動一個遞減1,往右滑動一個遞增1。下面通過實例代碼給大家講解swiper動態(tài)改變滑動內(nèi)容的實現(xiàn)方法,感興趣的朋友一起看看吧
    2018-01-01
  • JavaScript Event學(xué)習(xí)第四章 傳統(tǒng)的事件注冊模型

    JavaScript Event學(xué)習(xí)第四章 傳統(tǒng)的事件注冊模型

    在這一章我會講解給元素注冊事件的最好的一種辦法,那就是:確保一個特定的事件在特定的HTML元素上發(fā)生并且能運行特定的腳本。
    2010-02-02
  • 帶你用原生js寫一個簡單的注冊登錄頁面

    帶你用原生js寫一個簡單的注冊登錄頁面

    這篇文章主要給大家介紹了關(guān)于如何使用原生js寫一個簡單的注冊登錄頁面的相關(guān)資料,文中介紹了一個以js驗證表單的簡潔的注冊登錄頁面,需要的朋友可以參考下
    2023-06-06
  • 原生js封裝自定義滾動條

    原生js封裝自定義滾動條

    本文主要介紹了原生js封裝自定義滾動條的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • javascript支持IE和firefox(FF)的漸變透明效果

    javascript支持IE和firefox(FF)的漸變透明效果

    DataThis可以發(fā)送任何標(biāo)簽,這個標(biāo)簽沒有ID也可以,因為用的是自定義屬性。
    2008-10-10
  • JavaScript實現(xiàn)自己的DOM選擇器原理及代碼

    JavaScript實現(xiàn)自己的DOM選擇器原理及代碼

    實現(xiàn)自己的DOM選擇器時匹配行為也應(yīng)該和瀏覽原生匹配行為一致,接下來本文將詳細(xì)介紹下實現(xiàn)思路及方法,感興趣的你可以參考下或許對你鞏固知識有所幫助
    2013-03-03
  • 微信小程序開發(fā)之實現(xiàn)自定義Toast彈框

    微信小程序開發(fā)之實現(xiàn)自定義Toast彈框

    Toast相信對于利用微信小程序開發(fā)的朋友們來說都不陌生,有時候官方的樣式并不能滿足業(yè)務(wù)要求,怎么辦呢,當(dāng)然有解決辦法了。有一個插件可以直接幫我們完成WeToast,這篇文章主要給大家介紹了微信小程序開發(fā)之實現(xiàn)自定義Toast彈框的相關(guān)資料,需要的朋友可以參考下。
    2017-06-06
  • 最新評論