RN Turbo新架構(gòu)下JSI通信

在 React Native 0.74 新架構(gòu)下,iOS 開發(fā)人員需要從傳統(tǒng)的 RCTBridgeModule 遷移到 TurboModules 和 JSI 通信方式。下面是詳細(xì)的步驟撰筷,指導(dǎo) iOS 開發(fā)人員如何在新架構(gòu)下實(shí)現(xiàn)與 React Native 通信。每一步都盡可能詳細(xì)即舌,以便 iOS 開發(fā)人員無需了解太多 React Native 的細(xì)節(jié)也能完成遷移啦粹。

1. 概覽

在舊版本中,iOS 和 React Native 之間的通信是通過 RCTBridgeModule 實(shí)現(xiàn)的枝誊。這種方式是異步的况芒,使用了 React Native 的橋接機(jī)制。現(xiàn)在叶撒,在新架構(gòu)中绝骚,通信主要通過 TurboModules 和 JSI 實(shí)現(xiàn),它們提供了更高效的通信方式祠够。

2. 初步準(zhǔn)備

2.1 確保項(xiàng)目使用 React Native 0.74 版本

首先压汪,你需要確保你的項(xiàng)目已經(jīng)升級(jí)到 React Native 0.74 版本。如果你的項(xiàng)目還沒有升級(jí)古瓤,建議與負(fù)責(zé) React Native 升級(jí)的團(tuán)隊(duì)配合蛾魄,完成 React Native 的升級(jí)。

2.2 啟用新架構(gòu)

在新架構(gòu)中湿滓,TurboModules 和 Fabric 是核心組成部分滴须。你需要確保新架構(gòu)已在項(xiàng)目中啟用。

步驟:

  1. 更新 Podfile
    打開項(xiàng)目的 ios/Podfile 文件叽奥,確保包含以下配置:

    use_react_native!(
      :path => config[:reactNativePath],
      :fabric_enabled => true,
      :new_architecture_enabled => true
    )
    
  2. 安裝 CocoaPods 依賴
    ios 目錄中扔水,運(yùn)行以下命令來安裝依賴:

    cd ios
    pod install
    
  3. 構(gòu)建項(xiàng)目
    確保項(xiàng)目可以正常構(gòu)建并運(yùn)行:

    cd ..
    yarn ios
    

3. 編寫 TurboModule

TurboModule 是替代 RCTBridgeModule 的新方式,用于在新架構(gòu)中實(shí)現(xiàn)原生模塊與 JavaScript 的通信朝氓。

3.1 定義 TurboModule 的接口

TurboModule 的接口定義需要通過 TypeScript 或 Flow 來完成魔市。雖然這部分工作通常由 React Native 開發(fā)人員完成主届,但理解這一步有助于了解后續(xù)步驟。

// MyModuleSpec.ts

import { TurboModule, TurboModuleRegistry } from 'react-native';

export interface Spec extends TurboModule {
  openRouter(router: string, parameters: { [key: string]: any }): void;
  showHUD(): void;
}

export default TurboModuleRegistry.get<Spec>('MyModule');

3.2 生成代碼(由 RN 開發(fā)人員完成)

React Native 開發(fā)人員會(huì)使用 Codegen 工具生成相應(yīng)的 Objective-C 或 C++ 代碼待德,這些代碼會(huì)被集成到 iOS 項(xiàng)目中君丁。

4. 編寫 iOS 原生代碼

這是 iOS 開發(fā)人員的主要任務(wù)。你需要根據(jù)生成的接口實(shí)現(xiàn) TurboModule 的原生邏輯将宪。

4.1 創(chuàng)建 Objective-C++ 文件

ios 目錄中绘闷,創(chuàng)建一個(gè)新的文件夾(例如 MyModule),用于存放 TurboModule 的實(shí)現(xiàn)文件较坛。

4.2 實(shí)現(xiàn) TurboModule 的邏輯

創(chuàng)建一個(gè) MyModule.mm 文件印蔗,并實(shí)現(xiàn) TurboModule 的邏輯。

// MyModule.mm

#import <React/RCTLog.h>
#import <React/RCTViewManager.h>
#import <React/RCTBridgeModule.h>
#import <ReactCommon/RCTTurboModule.h>

@interface MyModule : NSObject <RCTTurboModule>
@end

@implementation MyModule

RCT_EXPORT_MODULE()

- (void)openRouter:(NSString *)router parameters:(NSDictionary *)parameters
{
  dispatch_async(dispatch_get_main_queue(), ^{
    [[SGRouterManager sharedInstance] openURL:router parameters:parameters];
  });
}

- (void)showHUD
{
  dispatch_async(dispatch_get_main_queue(), ^{
    [SVProgressHUD show];
  });
}

@end
  • RCT_EXPORT_MODULE():用于導(dǎo)出模塊丑勤,使其在 JavaScript 中可用华嘹。
  • RCTTurboModule:這是 TurboModule 的核心協(xié)議,取代了 RCTBridgeModule法竞。

4.3 實(shí)現(xiàn)與 JSI 的集成

為了提高通信效率耙厚,你可以選擇實(shí)現(xiàn) JSI 與原生代碼的直接集成。這涉及使用 C++ 實(shí)現(xiàn)部分代碼岔霸。

創(chuàng)建一個(gè) MyModule.cpp 文件:

#include <jsi/jsi.h>
#include <ReactCommon/TurboModuleUtils.h>
#include "MyModuleSpec.h"

using namespace facebook::jsi;
using namespace facebook::react;

class MyModule : public TurboModule {
public:
  MyModule(std::shared_ptr<CallInvoker> jsInvoker)
      : TurboModule("MyModule", jsInvoker) {}

  void openRouter(Runtime& rt, const std::string& router, const Object& parameters) {
    // 原生邏輯
    dispatch_async(dispatch_get_main_queue(), ^{
      [[SGRouterManager sharedInstance] openURL:[NSString stringWithUTF8String:router.c_str()] parameters:RCTConvert<NSDictionary *>(parameters)];
    });
  }

  void showHUD(Runtime& rt) {
    // 原生邏輯
    dispatch_async(dispatch_get_main_queue(), ^{
      [SVProgressHUD show];
    });
  }
};

這段代碼展示了如何使用 C++ 通過 JSI 直接與 JavaScript 通信颜曾,而不再依賴傳統(tǒng)的橋接方式。

5. 集成與調(diào)試

5.1 將模塊集成到項(xiàng)目中

確保你將所有實(shí)現(xiàn)的代碼集成到 Xcode 項(xiàng)目中秉剑,并確保它們在項(xiàng)目的編譯設(shè)置中是正確的泛豪。

5.2 測試 TurboModule

  • 在 Xcode 中運(yùn)行項(xiàng)目,確保模塊能夠被正確調(diào)用侦鹏,并且通信是有效的诡曙。
  • 如果遇到問題,檢查 Xcode 控制臺(tái)日志略水,調(diào)試原生代碼與 JavaScript 代碼之間的交互价卤。

6. 總結(jié)與最佳實(shí)踐

  • 新架構(gòu)的優(yōu)勢:通過遷移到 TurboModule 和 JSI,你可以享受更高效的通信和更好的性能渊涝,這在高頻交互場景中尤為重要慎璧。
  • 漸進(jìn)式遷移:可以逐步將舊的 RCTBridgeModule 遷移到 TurboModule,確保每個(gè)模塊的穩(wěn)定性跨释。
  • 與 RN 團(tuán)隊(duì)協(xié)作:在遷移過程中胸私,與負(fù)責(zé) React Native 部分的開發(fā)團(tuán)隊(duì)緊密合作,確保接口定義與原生實(shí)現(xiàn)的一致性鳖谈。
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末岁疼,一起剝皮案震驚了整個(gè)濱河市,隨后出現(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ī)與錄音窍奋,去河邊找鬼荐健。 笑死,一個(gè)胖子當(dāng)著我的面吹牛琳袄,可吹牛的內(nèi)容都是我干的江场。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼窖逗,長吁一口氣:“原來是場噩夢啊……” “哼扛稽!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起滑负,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤在张,失蹤者是張志新(化名)和其女友劉穎用含,沒想到半個(gè)月后,有當(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
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了瘟斜。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片缸夹。...
    茶點(diǎn)故事閱讀 40,137評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖螺句,靈堂內(nèi)的尸體忽然破棺而出虽惭,到底是詐尸還是另有隱情,我是刑警寧澤蛇尚,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布芽唇,位于F島的核電站,受9級(jí)特大地震影響取劫,放射性物質(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. 我叫王不留箩艺,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓宪萄,卻偏偏與公主長得像艺谆,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子拜英,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,086評論 2 355

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