RN調用iOS珍逸、iOS調用RN 在我看來就像去書店買書一樣
你掏錢買書逐虚,店員把書給你,你和書之間需要一個店員才能完成買書的過程谆膳,你(RN)掏錢的這個舉動叭爱,就相當于RN發(fā)送了一個action,店員(iOS)看到你的action漱病,然后就把書給你买雾。
首先要有一個準備工作(你準備去書店,書店準備好書)
iOS
首先要創(chuàng)建一個類
#import <Foundation/Foundation.h>
//這里有的也可以寫成 #import "RCTBridgeModule.h"
//不過我的項目這樣寫有錯杨帽,
#import <React/RCTBridgeModule.h>
@interface RNCalliOSAction : NSObject<RCTBridgeModule>
@end
#import "RNCalliOSAction.h"
#import <UIKit/UIKit.h>
#import "SVProgressHUD.h"
//#import "RCSubEventEmitter.h"
//iOS調用RN
#import <React/RCTEventDispatcher.h>
@interface RNCalliOSAction ()
@end
@implementation RNCalliOSAction
@synthesize bridge = _bridge;
//導出模塊
RCT_EXPORT_MODULE(); //此處不添加參數(shù)即默認為這個OC類的名字
//導出方法漓穿,橋接到js的方法返回值類型必須是void
/*
iOS支持方法名一樣但是參數(shù)不一樣的方法,視為兩個不同的方法
但是RN調用iOS這樣的方法會出錯的
所以最好別把方法名聲明成一樣的
*/
/**************************************** RN Call iOS ***************************************************/
//一個參數(shù)
RCT_EXPORT_METHOD(calliOSActionWithOneParams:(NSString *)name)
{
}
書店(iOS)已經準備好了注盈,下面該你(RN)準備了
React Native
import {
NativeModules,
NativeAppEventEmitter,//導入
} from 'react-native';
//在JavaScript中調用Object-C定義的方法晃危,需要先導入NativeModules
//此處的RNCalliOSAction就是我們在iOS上新建的類名
//如果在iOS中設置了導出了類的名字,此處需要和導出的名字一致
var RNCalliOSAction = NativeModules.RNCalliOSAction;
準備結束
先看你掏錢的舉動吧(RN->iOS)
<TouchableOpacity style={{height:30}}
onPress={()=>{
//此處向iOS發(fā)出一個action(就是你掏錢嘍)
RNCalliOSAction.calliOSActionWithOneParams('hello');
}}>
<Text>點擊調用iOS原生方法,RN向iOS傳遞一個參數(shù)</Text>
</TouchableOpacity>
店員收到你的錢啦
//一個參數(shù)
RCT_EXPORT_METHOD(calliOSActionWithOneParams:(NSString *)name)
{
[SVProgressHUD setDefaultMaskType:SVProgressHUDMaskTypeBlack];
[SVProgressHUD showSuccessWithStatus:[NSString stringWithFormat:@"參數(shù):%@",name]];
}
然后就可以把書給你了
書店準備工作
#import <React/RCTEventDispatcher.h>
@implementation RNCalliOSAction
@synthesize bridge = _bridge;
@end
準備完成老客,給你書
//name:就是你啦
//body:就是給你的書(數(shù)據(jù))
[self.bridge.eventDispatcher sendAppEventWithName:@"getSelectDate" body:@{@"SelectDate":str_date}];
然后你去接書
componentDidMount (){
//在書店等著僚饭,書店什么時候給你書,你什么時候拿到書寫名字啦裝進書包了等等
this.listener=NativeAppEventEmitter.addListener('getSelectDate',(data)=>{
console.log('data'+JSON.stringify(data));
console.log('selectDate:'+data.SelectDate);
})
}
componentWillUnmount(){
//買書過程完畢胧砰,消除你來過書店的記錄
this.listener.remove();
}
這樣整個過程over
當然代碼是挑出來描述整個過程的
以下是完整的代碼包含: