ReactNative与原生通信

1. 从原生组件传递属性到React Native(原生->RN)

通过RCTRootView将属性传给RN

iOS代码如下

NSDictionary *props = @{@"desc":@"hello, fuck you"};
RCTRootView *rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation
                                                      moduleName:@"XYMobileTest"
                                               initialProperties:props
                                                   launchOptions:nil];
MainViewController* vc = [[MainViewController alloc] init];
vc.view = rootView;

2. 从React Native传递属性到原生组件(RN->原生)

2.1 iOS做如下修改

  • 引入#import 以及协议
  • 必须实现RCT_EXPORT_MODULE()方法
  • 设置你自定义的方法
RCT_EXPORT_METHOD(testName:(NSString *)name){
  NSLog(@"%@",name);
};

2.2 JS做如下修改

  • 引入import { NativeModules } from 'react-native';
  • 使用OC中定义的方法
let connection = NativeModules.XYConnection;
connection.testName('Will');

具体可见一个demo,欢迎✨✨✨

你可能感兴趣的:(ReactNative与原生通信)