React Native 避免崩潰

最近在做一個(gè)RN項(xiàng)目璧尸,其中出現(xiàn)了一個(gè)崩潰問(wèn)題涌萤,原因是服務(wù)端數(shù)據(jù)結(jié)構(gòu)變更導(dǎo)致RN代碼報(bào)錯(cuò)“r.includes is not a function”番舆。這么小的問(wèn)題在瀏覽器里面不算什么贫橙,但是RN就會(huì)導(dǎo)致崩潰,iOS表現(xiàn)形式是閃退畅姊,Android是卡死咒钟,非常嚴(yán)重,值得我們重視若未。

那么朱嘴,都有哪些問(wèn)題會(huì)導(dǎo)致崩潰呢?

簡(jiǎn)單來(lái)說(shuō)陨瘩,語(yǔ)法錯(cuò)誤都會(huì)引起崩潰腕够。這些語(yǔ)法錯(cuò)誤在調(diào)試模式會(huì)顯示為紅屏報(bào)錯(cuò)级乍,release包不會(huì)顯示,會(huì)直接崩潰帚湘。


紅屏示例
那RN為什么要如此設(shè)計(jì)呢玫荣?

js是弱類(lèi)型語(yǔ)言,在轉(zhuǎn)譯成OC大诸,Java或者對(duì)其調(diào)用時(shí)就需要嚴(yán)格處理捅厂。

我們應(yīng)該注意哪些場(chǎng)景呢?
  1. 接收的服務(wù)端數(shù)據(jù)結(jié)構(gòu)類(lèi)型资柔;
  2. 調(diào)用的NativeModule或者第三方模塊焙贷;
  3. 容易出錯(cuò)的方法需要足夠"健壯";
  4. render等核心功能的錯(cuò)誤處理贿堰;

如此辙芍,自然想到兩個(gè)辦法來(lái)應(yīng)對(duì)以上場(chǎng)景:

  1. 調(diào)用方法前判斷類(lèi)型,不應(yīng)該調(diào)用該類(lèi)型沒(méi)有的方法羹与,比如string, object, array等; 比如開(kāi)篇提到的錯(cuò)誤“r.includes is not a function”故硅,我們是提前判斷對(duì)象是否為字符串來(lái)解決的:
-- r.includes('abc');
++ const isValid = typeof r == 'string';
++ isValid && r.includes('abc');

使用的bugly監(jiān)控平臺(tái)的數(shù)據(jù)證明了這個(gè)方法有效:


降低崩潰率.png
  1. 使用try, catch;

這樣可以避免報(bào)錯(cuò)引起崩潰了。但是纵搁,這樣加判斷吃衅,套try, catch代碼好丑,有些冗余腾誉,而且這種約定容易被忽略徘层。

有沒(méi)有自動(dòng)化的解決方案呢?
1. 代碼檢測(cè)

代碼檢測(cè)又可以分為兩個(gè)階段:

  1. 編譯階段利职,這個(gè)階段使用的工具就是Facebook提供的打包工具趣效,已經(jīng)有一些問(wèn)題可以被發(fā)現(xiàn),比如文件找不到等眼耀;
  2. 編程階段英支,這個(gè)階段就是在保存文件之前,調(diào)用編譯工具之前哮伟,可以使用vscode等編輯器配置eslint來(lái)做高亮提示,如下圖:


    vscode-eslint提示.png
2. 運(yùn)行時(shí)處理

在瀏覽器環(huán)境我們可以使用window.onerror來(lái)監(jiān)聽(tīng)全局報(bào)錯(cuò)妄帘,做統(tǒng)一的錯(cuò)誤處理楞黄,或統(tǒng)計(jì),甚至告警抡驼,對(duì)于我們及時(shí)發(fā)現(xiàn)線上問(wèn)題鬼廓,排查問(wèn)題非常有幫助。
RN環(huán)境致盟,可以使用global.ErrorUtils錯(cuò)誤工具提供的setGlobalHandler方法處理, 比如:

global.ErrorUtils.setGlobalHandler(error => {
  console.log('ErrorUtils發(fā)現(xiàn)了語(yǔ)法錯(cuò)誤碎税,避免了崩潰尤慰,具體報(bào)錯(cuò)信息:');
  console.log(error.name, error.message, [{ text: 'OK' }]);
}, true);

利用ErrorUtils.setGlobalHandler,我們就可以避免崩潰雷蹂,統(tǒng)一處理問(wèn)題伟端,但如果你不希望統(tǒng)一處理,那么你就可以在特殊的代碼“套上”try, catch, 這個(gè)方法可以根據(jù)返回的error對(duì)象找到對(duì)應(yīng)的錯(cuò)誤類(lèi)型匪煌,行數(shù)责蝠,文件等信息,該方法源碼請(qǐng)參考:Facebook Github: InitializeJavaScriptAppEngine.js
另外萎庭,react-native-exception-handler也可以統(tǒng)一處理報(bào)錯(cuò)霜医,另外它也可以處理Native端的報(bào)錯(cuò)。
再說(shuō)一句React的ComponentDidCatch驳规,這個(gè)更適用于頁(yè)面基本的錯(cuò)誤監(jiān)控肴敛,而且低版本不支持該生命周期。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末吗购,一起剝皮案震驚了整個(gè)濱河市值朋,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌巩搏,老刑警劉巖昨登,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異贯底,居然都是意外死亡丰辣,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)禽捆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)笙什,“玉大人,你說(shuō)我怎么就攤上這事胚想∷銎荆” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵浊服,是天一觀的道長(zhǎng)统屈。 經(jīng)常有香客問(wèn)我,道長(zhǎng)牙躺,這世上最難降的妖魔是什么愁憔? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮孽拷,結(jié)果婚禮上吨掌,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好膜宋,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布窿侈。 她就那樣靜靜地躺著,像睡著了一般秋茫。 火紅的嫁衣襯著肌膚如雪史简。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,541評(píng)論 1 305
  • 那天学辱,我揣著相機(jī)與錄音乘瓤,去河邊找鬼。 笑死策泣,一個(gè)胖子當(dāng)著我的面吹牛衙傀,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播萨咕,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼统抬,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了危队?” 一聲冷哼從身側(cè)響起聪建,我...
    開(kāi)封第一講書(shū)人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎茫陆,沒(méi)想到半個(gè)月后金麸,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡簿盅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年挥下,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片桨醋。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡棚瘟,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出喜最,到底是詐尸還是另有隱情偎蘸,我是刑警寧澤,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布瞬内,位于F島的核電站迷雪,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏遂鹊。R本人自食惡果不足惜振乏,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望秉扑。 院中可真熱鬧,春花似錦、人聲如沸舟陆。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)秦躯。三九已至忆谓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間踱承,已是汗流浹背倡缠。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留茎活,地道東北人昙沦。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像载荔,于是被迫代替她去往敵國(guó)和親盾饮。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355