無星的RN學(xué)習(xí)之旅(三)-bridge is not set.

報錯信息:bridge is not set. This is probably because you've "
"explicitly synthesized the bridge in %@, even though it's inherited "
"from RCTEventEmitter.

踩坑了蜀细。瓜浸。淋纲。
我相信肯定有兄弟需要從原生的OC向RN主動發(fā)起事件刽射。而且這種場景也很多屈芜,比如集成第三方的服務(wù)拍棕,通過代理回調(diào)獲取結(jié)果發(fā)送給RN等等等等揪荣。宇葱。瘦真。
我將我遇到的坑總結(jié)一下吧。
先看下官網(wǎng)怎么寫的

官網(wǎng)介紹1
官網(wǎng)介紹2.png

1.你是不是像官網(wǎng)一樣黍瞧,先寫一個繼承自RCTEventEmitter的對象诸尽,什么都不寫,看看能不能運(yùn)行印颤?
答案是:并不能運(yùn)行=您机。=你必須寫實(shí)現(xiàn),也就是以下這個方法

//.m文件
- (NSArray<NSString *> *)supportedEvents
{
  return @[@"EventReminder"];
}

2.你在使用發(fā)送文件年局,也就是

[self sendEventWithName:@"消息名" body:參數(shù)];

運(yùn)行這個方法的時候有沒有崩潰啊=际看。=
崩潰的提示是不是

bridge is not set. This is probably because you've "
            "explicitly synthesized the bridge in %@, even though it's inherited "
            "from RCTEventEmitter.

其實(shí)就是bridage為空。
這個時候你查這個報錯提示是不是發(fā)現(xiàn)有人說在Appdelegate.m里把rootView的bridage賦給這個你創(chuàng)建的對象矢否,然后你試了一下確實(shí)發(fā)出去了開始哈皮=仿村。=

這時候你會發(fā)現(xiàn)一個悲傷的事實(shí),不管你在RN里怎么寫監(jiān)聽兴喂,你都監(jiān)聽不到這個事件=蔼囊。=
那么正確的解法是什么呢=。=
(1)必須使用單例
(2)必須復(fù)寫alloczone
其實(shí)就是加這么一段代碼:

//.m文件
+(id)allocWithZone:(NSZone *)zone {
  static RNBridge *sharedInstance = nil;
  static dispatch_once_t onceToken;
  dispatch_once(&onceToken, ^{
    sharedInstance = [super allocWithZone:zone];
  });
  return sharedInstance;
}

在APPdelegate中就不需要將rootView的bridge賦予原生模塊了衣迷。
用self進(jìn)行發(fā)送即可
RN中使用NativeEventEmitter進(jìn)行監(jiān)聽即可畏鼓。
還有問題簡書私信我,一起交流解決=壶谒。=

2017-12-22更新

還是有兄弟對于iOS與RN的交互有問題云矫,直接上代碼吧。圖片名會寫明是在橋接類的.h還是.m文件的代碼


.h.png
.m.png
.m.png
.m.png

接下來是js方面如何監(jiān)聽

js.png
js.png

這里要注意了汗菜,下面這幅截圖中的代碼让禀,如果使用DevicceEventEmitter無法監(jiān)聽到的話挑社,用我圖中寫的對應(yīng)自己原生模塊的nativeBridgeEmitter(名字自取)去監(jiān)聽巡揍。


js.png

理論上痛阻,只要你的RN方面的服務(wù)以及模塊已經(jīng)啟動,那就可以順暢的進(jìn)行oc的主動通信腮敌,不然是無法通信而且會導(dǎo)致崩潰的阱当。

無星的RN學(xué)習(xí)之旅(一)-環(huán)境安裝以及新建項(xiàng)目
無星的RN學(xué)習(xí)之旅(二)-RN與原生的通信
無星的RN學(xué)習(xí)之旅(四)——通信、持久化存儲糜工、xcode打包
無星的RN學(xué)習(xí)之旅(五)-關(guān)于react-navigation多層級頁面返回時弊添,去掉逐層推出動畫
無星的RN學(xué)習(xí)之旅(六)-第三方App跳轉(zhuǎn),蘋果商店跳轉(zhuǎn)捌木,loading框

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末油坝,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子刨裆,更是在濱河造成了極大的恐慌免钻,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件崔拥,死亡現(xiàn)場離奇詭異极舔,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)链瓦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進(jìn)店門拆魏,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人慈俯,你說我怎么就攤上這事渤刃。” “怎么了贴膘?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵卖子,是天一觀的道長。 經(jīng)常有香客問我刑峡,道長洋闽,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任突梦,我火速辦了婚禮诫舅,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘宫患。我一直安慰自己刊懈,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著虚汛,像睡著了一般匾浪。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上卷哩,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天蛋辈,我揣著相機(jī)與錄音,去河邊找鬼殉疼。 笑死,一個胖子當(dāng)著我的面吹牛捌年,可吹牛的內(nèi)容都是我干的瓢娜。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼礼预,長吁一口氣:“原來是場噩夢啊……” “哼眠砾!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起托酸,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤褒颈,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后励堡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體谷丸,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年应结,在試婚紗的時候發(fā)現(xiàn)自己被綠了刨疼。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,137評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡鹅龄,死狀恐怖揩慕,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情扮休,我是刑警寧澤迎卤,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站玷坠,受9級特大地震影響蜗搔,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜八堡,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一碍扔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧秕重,春花似錦不同、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽服鹅。三九已至,卻和暖如春百新,著一層夾襖步出監(jiān)牢的瞬間企软,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工饭望, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留仗哨,地道東北人。 一個月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓铅辞,卻偏偏與公主長得像厌漂,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子斟珊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評論 2 355

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