RN|RNiOS 互相调用方法
RN调用iOS、iOS调用RN 在我看来就像去书店买书一样
你掏钱买书,店员把书给你,你和书之间需要一个店员才能完成买书的过程,你(RN)掏钱的这个举动,就相当于RN发送了一个action,店员(iOS)看到你的action,然后就把书给你。首先要有一个准备工作(你准备去书店,书店准备好书) 【RN|RNiOS 互相调用方法】
iOS
首先要创建一个类
#import //这里有的也可以写成 #import "RCTBridgeModule.h"
//不过我的项目这样写有错,
#import @interface RNCalliOSAction : NSObject@end
#import "RNCalliOSAction.h"#import #import "SVProgressHUD.h"//#import "RCSubEventEmitter.h"//iOS调用RN
#import @interface RNCalliOSAction ()@end@implementation RNCalliOSAction@synthesize bridge = _bridge;
//导出模块
RCT_EXPORT_MODULE();
//此处不添加参数即默认为这个OC类的名字//导出方法,桥接到js的方法返回值类型必须是void/*
iOS支持方法名一样但是参数不一样的方法,视为两个不同的方法
但是RN调用iOS这样的方法会出错的
所以最好别把方法名声明成一样的
*//**************************************** RN Call iOS ***************************************************///一个参数
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)
{
//此处向iOS发出一个action(就是你掏钱喽)
RNCalliOSAction.calliOSActionWithOneParams('hello');
}}>
点击调用iOS原生方法,RN向iOS传递一个参数
店员收到你的钱啦
//一个参数
RCT_EXPORT_METHOD(calliOSActionWithOneParams:(NSString *)name)
{[SVProgressHUD setDefaultMaskType:SVProgressHUDMaskTypeBlack];
[SVProgressHUD showSuccessWithStatus:[NSString stringWithFormat:@"参数:%@",name]];
}
然后就可以把书给你了 书店准备工作
#import
@implementation RNCalliOSAction@synthesize bridge = _bridge;
@end
准备完成,给你书
//name:就是你啦
//body:就是给你的书(数据)
[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
当然代码是挑出来描述整个过程的
以下是完整的代码包含:
QQ20170505-181305.gif QQ20170505-181017.gif demo:https://github.com/chjwrr/RNAndiOSCallEachOther
推荐阅读
- Linux|Linux awk命令详解
- Python封装SNMP调用接口的示例代码
- Python|Python 封装SNMP调用接口
- JavaScript中函数的常用写法及调用方法
- Yii|Yii2中不同模块之间的调用runAction
- Objective-C|Objective-C 懒加载没有调用()
- 02|02 编写C语言,调用ffmpeg
- iOS-拍照和调用本地图片
- 点播 构造自己的播放器 用户调用获取视频播放地址接口
- uni-app 项目引入第三方js插件,单个js文件引入成功,调用该插件方法