React-Native --DeviceEventEmitter(-)

最近在用RN仿半糖app的時候,發(fā)現(xiàn)半糖有個小細(xì)節(jié)做的感覺挺不錯的。用戶初次進入到app內(nèi)的時候,tabbar的‘我的’圖標(biāo)來源是一張導(dǎo)入的圖片文件。然后當(dāng)用戶再點擊"我的"頁面的時候,開始請求網(wǎng)絡(luò)數(shù)據(jù),再獲得用戶頭像的url的時候,實時得也刷新了底部tabbar的"我的"圖標(biāo)的來源,這時候不再使用工程內(nèi)的文件,而是網(wǎng)絡(luò)加載頭像url。具體如圖。

初次進入app.png

通知刷新tabbar后.png

實現(xiàn)

1.半糖的ios應(yīng)用在實現(xiàn)這個小細(xì)節(jié)是應(yīng)該是使用了NSNotificationcenter,然后我在想RN的通知該去怎么實現(xiàn),后來百度到 DeviceEventEmitter 。

2.DeviceEventEmitter在RN內(nèi)的發(fā)送和接受消息。例如:

A頁面注冊通知:

import  {DeviceEventEmitter} from 'react-native';
//…
//調(diào)用事件通知
DeviceEventEmitter.emit('xxxName’,param);
//xxxName:通知的名稱 param:發(fā)送的消息(傳參)

B頁面接收通知:

componentDidMount(){
    var self = this;
    this.listener =DeviceEventEmitter.addListener('xxxName',function(param){

    //  use param do something
    });
}
//xxxName:通知的名稱    param:接收到的消息(傳參)

componentWillUnmount(){
      this.listener.remove();
  }

//在componentWillUnmount 內(nèi)需要我們手動移除通知

3.知道DeviceEventEmitter的簡單使用后,我們開始在RN版的半糖開始實現(xiàn)我們需要的小功能吧。

我的頁面在獲取到用戶數(shù)據(jù)后:

  //注冊監(jiān)聽事件,時間名稱:changeMine  傳參:jsonData.avatar(頭像url)
    DeviceEventEmitter.emit('changeMine',jsonData.avatar);

tabbar.js 文件:

componentDidMount(){

    var self = this;
    this.listener = DeviceEventEmitter.addListener('changeMine',function(url){
        self.setState({
          avatar:url
        })
    });

//通知開始,獲取到url,調(diào)用setState 方法,刷新狀態(tài)機,這時候?qū)崟r的刷新了‘我的’圖標(biāo)

//最后別忘了移除通知
componentWillUnmount(){
      this.listener.remove();
  }
2017-04-18 11_39_08.gif
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,027評論 25 709
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 15,274評論 4 61
  • 今天看了周沖的文章,受打擊了! 啥也不想寫了 晚安
    林素兮閱讀 320評論 10 2
  • 為什么要寫這篇文章,是因為當(dāng)時自己在做檢查的前期一直在找相關(guān)的信息,想知道疼不疼,要不要麻醉之類的。現(xiàn)在寫下...
    肖笑笑star閱讀 34,012評論 4 3
  • 1 看到過一個報道,深澤直人在為無印良品設(shè)計那款經(jīng)典款壁掛式CD機時,為了尋找一款拉動后延遲一秒再啟動的電機,幾乎...
    引光咖啡館閱讀 550評論 1 2

友情鏈接更多精彩內(nèi)容