RN调用iOS、iOS调用RN

2018-04-01  本文已影响0人  冯汉栩

RN调用iOS、iOS调用RN 在我看来就像去书店买书一样

你掏钱买书,店员把书给你,你和书之间需要一个店员才能完成买书的过程,你(RN)掏钱的这个举动,就相当于RN发送了一个action,店员(iOS)看到你的action,然后就把书给你。

首先要有一个准备工作(你准备去书店,书店准备好书)

iOS

首先要创建一个类

#import//这里有的也可以写成 #import "RCTBridgeModule.h"//不过我的项目这样写有错,#import@interfaceRNCalliOSAction:NSObject@end

#import"RNCalliOSAction.h"#import#import"SVProgressHUD.h"//#import "RCSubEventEmitter.h"//iOS调用RN#import@interfaceRNCalliOSAction()@end@implementationRNCalliOSAction@synthesizebridge = _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中设置了导出了类的名字,此处需要和导出的名字一致varRNCalliOSAction = NativeModules.RNCalliOSAction;

准备结束

先看你掏钱的举动吧(RN->iOS)

{                //此处向iOS发出一个action(就是你掏钱喽)RNCalliOSAction.calliOSActionWithOneParams('hello');            }}>点击调用iOS原生方法,RN向iOS传递一个参数

店员收到你的钱啦

//一个参数RCT_EXPORT_METHOD(calliOSActionWithOneParams:(NSString*)name){    [SVProgressHUD setDefaultMaskType:SVProgressHUDMaskTypeBlack];  [SVProgressHUD showSuccessWithStatus:[NSStringstringWithFormat:@"参数:%@",name]];  }

然后就可以把书给你了

书店准备工作

#import@implementationRNCalliOSAction@synthesizebridge = _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

作者:精神病患者link常

链接:https://www.jianshu.com/p/9ea9d82a386b

來源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

上一篇 下一篇

猜你喜欢

热点阅读