React-Native --DeviceEventEmitter(-)

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

初次進入app.png

通知刷新tabbar后.png

實現(xiàn)

1.半糖的ios應用在實現(xiàn)這個小細節(jié)是應該是使用了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的刷新了‘我的’圖標

//最后別忘了移除通知
componentWillUnmount(){
      this.listener.remove();
  }
2017-04-18 11_39_08.gif
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末家坎,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子吝梅,更是在濱河造成了極大的恐慌虱疏,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,104評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件苏携,死亡現(xiàn)場離奇詭異做瞪,居然都是意外死亡,警方通過查閱死者的電腦和手機装蓬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評論 3 399
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來儡遮,“玉大人鄙币,你說我怎么就攤上這事蹂随。” “怎么了绩衷?”我有些...
    開封第一講書人閱讀 168,697評論 0 360
  • 文/不壞的土叔 我叫張陵唇聘,是天一觀的道長柱搜。 經(jīng)常有香客問我聪蘸,道長,這世上最難降的妖魔是什么控乾? 我笑而不...
    開封第一講書人閱讀 59,836評論 1 298
  • 正文 為了忘掉前任蜕衡,我火速辦了婚禮,結(jié)果婚禮上慨仿,老公的妹妹穿的比我還像新娘纳胧。我一直安慰自己,他們只是感情好跑慕,可當我...
    茶點故事閱讀 68,851評論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著牢硅,像睡著了一般。 火紅的嫁衣襯著肌膚如雪综苔。 梳的紋絲不亂的頭發(fā)上休里,一...
    開封第一講書人閱讀 52,441評論 1 310
  • 那天,我揣著相機與錄音瞧剖,去河邊找鬼可免。 笑死,一個胖子當著我的面吹牛捉撮,可吹牛的內(nèi)容都是我干的巾遭。 我是一名探鬼主播,決...
    沈念sama閱讀 40,992評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼涨薪!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起献丑,我...
    開封第一講書人閱讀 39,899評論 0 276
  • 序言:老撾萬榮一對情侶失蹤阳距,失蹤者是張志新(化名)和其女友劉穎筐摘,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,457評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡圃酵,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,529評論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了馍管。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,664評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡确沸,死狀恐怖捌锭,靈堂內(nèi)的尸體忽然破棺而出罗捎,到底是詐尸還是另有隱情观谦,我是刑警寧澤,帶...
    沈念sama閱讀 36,346評論 5 350
  • 正文 年R本政府宣布桨菜,位于F島的核電站豁状,受9級特大地震影響倒得,放射性物質(zhì)發(fā)生泄漏泻红。R本人自食惡果不足惜谊路,卻給世界環(huán)境...
    茶點故事閱讀 42,025評論 3 334
  • 文/蒙蒙 一菩彬、第九天 我趴在偏房一處隱蔽的房頂上張望挤巡。 院中可真熱鬧剩彬,春花似錦、人聲如沸喉恋。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,511評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽琴昆。三九已至氓鄙,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間业舍,已是汗流浹背抖拦。 一陣腳步聲響...
    開封第一講書人閱讀 33,611評論 1 272
  • 我被黑心中介騙來泰國打工升酣, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人态罪。 一個月前我還...
    沈念sama閱讀 49,081評論 3 377
  • 正文 我出身青樓噩茄,卻偏偏與公主長得像,于是被迫代替她去往敵國和親复颈。 傳聞我的和親對象是個殘疾皇子绩聘,可洞房花燭夜當晚...
    茶點故事閱讀 45,675評論 2 359

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

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