RN <~> iOS 互相調用方法

RN調用iOS、iOS調用RN 在我看來就像去書店買書一樣

你掏錢買書,店員把書給你,你和書之間需要一個店員才能完成買書的過程,你(RN)掏錢的這個舉動,就相當于RN發送了一個action,店員(iOS)看到你的action,然后就把書給你。

首先要有一個準備工作(你準備去書店,書店準備好書)

iOS
首先要創建一個類

#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();    //此處不添加參數即默認為這個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)

<TouchableOpacity style={{height:30}}
                            onPress={()=>{
                //此處向iOS發出一個action(就是你掏錢嘍)
RNCalliOSAction.calliOSActionWithOneParams('hello');
            }}>
              <Text>點擊調用iOS原生方法,RN向iOS傳遞一個參數</Text>
          </TouchableOpacity>

店員收到你的錢啦

//一個參數
RCT_EXPORT_METHOD(calliOSActionWithOneParams:(NSString *)name)
{
  
  [SVProgressHUD setDefaultMaskType:SVProgressHUDMaskTypeBlack];
  [SVProgressHUD showSuccessWithStatus:[NSString stringWithFormat:@"參數:%@",name]];
  
}

然后就可以把書給你了

書店準備工作

#import <React/RCTEventDispatcher.h>
@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

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容