原生与RN通信

RN与原生的通信

此文以iOS与RN通信为例实现了

1.RN给原生发消息:RN调用原生方法,传递参数 

原生中导出MODULEMETHOD供RN调用

RCT_EXPORT_MODULE(PushNative)

// RN跳转原生界面

RCT_EXPORT_METHOD(RNOpenChatVCWithUserInfo:(NSDictionary *)userInfo){

    dispatch_async(dispatch_get_main_queue(), ^{

      RootTabBarController *tabBar = [RootTabBarController new];

      AppDelegate *app = (AppDelegate *)[[UIApplication sharedApplication] delegate];

      [app.nav pushViewController:tabBar animated:NO];

    });

  }

 

RN中 先导入,再调用

import { ..., NativeModules } from 'react-native'

NativeModules.PushNative.RNOpenChatVCWithUserInfo(UserInfo)

 

2.原生给RN发消息:原生通讯类发出消息事件,RN中捕捉

原生发出消息事件

PushNative * pushNative = [PushNative shareInstance];
[pushNative sendEventWithName:@"onCloseWithIndex" body:@{@"selIndex": @0}];

RN中

import {...,NativeModules,NativeEventEmitter} from 'react-native'

const PushNativeEmitter = new NativeEventEmitter(NativeModules.PushNative);

this.listener = PushNativeEmitter.addListener('onCloseWithIndex', (obj) => { // 处理 }

 

上面为通信逻辑,具体实现为通信类

#import <Foundation/Foundation.h>
#import <React/RCTBridgeModule.h>
#import <React/RCTEventEmitter.h>
#import <React/RCTBridge.h>
#import <React/RCTEventDispatcher.h>

NS_ASSUME_NONNULL_BEGIN

@interface PushNative : RCTEventEmitter <RCTBridgeModule>

+(instancetype)shareInstance;

@end

NS_ASSUME_NONNULL_END

----------------------上通信类.h   下通信类.m---------------



#import "PushNative.h"
#import "AppDelegate.h"
#import "BaseNav.h"
#import "RootTabBarController.h"

@implementation PushNative

static PushNative* _instance = nil;
+(instancetype)shareInstance
{
  static dispatch_once_t onceToken ;
  dispatch_once(&onceToken, ^{
    _instance = [[super allocWithZone:NULL] init] ;
  }) ;
  return _instance;
}
+ (instancetype)allocWithZone:(struct _NSZone *)zone{
  return [PushNative shareInstance] ;
}

RCT_EXPORT_MODULE(PushNative)

- (NSArray<NSString *> *)supportedEvents
{
  return @[@"onCloseWithIndex"];
}

// RN跳转原生界面
RCT_EXPORT_METHOD(RNOpenChatVCWithUserInfo:(NSDictionary *)userInfo){
  
    dispatch_async(dispatch_get_main_queue(), ^{

      RootTabBarController *tabBar = [RootTabBarController new];
      
      AppDelegate *app = (AppDelegate *)[[UIApplication sharedApplication] delegate];
      [app.nav pushViewController:tabBar animated:NO];
    });

  }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值