React-Native 桥接iOS原生开发详解
时间:2019-04-12
本文章向大家介绍React-Native 桥接iOS原生开发详解,主要包括React-Native 桥接iOS原生开发详解使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
react-native的文档的原生模块中可以看到清洗的代码 传送门
接下来先说一下笔者的要实现的功能:
在iOS原生代码中集成高德导航,在RN中用JS去调用原声代码,并进行跳转,
接下来是笔者遇到的问题与不好理解的地方,写出来跟大家分享让大家少走弯路.
刚开始也是一头雾水且查资料也是到处都是但是都没有解决问题.
iOS原生写法
在iOS中创建类继承NSObject(OC语言).
//类的.h文件 #import <Foundation/Foundation.h> #import <React/RCTBridgeModule.h> #import <React/RCTLog.h> #import <React/RCTUIManager.h> @interface GaoMapManager : NSObject<RCTBridgeModule> @end // 类的.m文件 #import "GaoMapManager.h" #import <AMapNaviKit/AMapNaviKit.h> #import <UIKit/UIKit.h> #import "GPSNaviViewController.h" @implementation GaoMapManager @synthesize bridge = _bridge; RCT_EXPORT_MODULE(); RCT_EXPORT_METHOD ( pushViewControllerXYZ:(nonnull NSNumber *)reactTag ) { RCTUIManager *uiManager = _bridge.uiManager; GPSNaviViewController *gps = [[GPSNaviViewController alloc] init]; dispatch_async(uiManager.methodQueue, ^{ [uiManager addUIBlock:^(RCTUIManager *uiManager, NSDictionary<NSNumber *,UIView *> *viewRegistry) { UIView * view = viewRegistry[reactTag]; UIViewController *vc = (UIViewController *)view.reactViewController; [vc presentViewController:gps animated:YES completion:^{ }]; }]; }); }
以上是全部iOS端的类文件的代码.当然继承高德地图是需要在AppDelegate.m文件中注册高德apiKey(如果地图不显示,Xcode中会显示错误,apikey不生效需要10分钟之后生效且一个key对应一个app,否者会出错)
RN中写法
看到这大家如果认真看了上面的代码,会注意到reactTag这个参数,在JS中怎么传这个参数呢,又代表着什么意思
其实很简单
import { NativeModules } from 'react-native'; export default NativeModules.GaoMapManager;
这是笔者写的一个untils的CommoniOSUtils.JS文件.调用的时候直接用文件名调用iOS原生的方法名即可
// findNodeHandle(this.homeHead)就是对应的reactTag参数的值 CommoniOSUtils.pushViewControllerXYZ(findNodeHandle(this.homeHead));
findNodeHandle引入方式
import { findNodeHandle, } from 'react-native';
看到这里大家应该清楚怎么回事了.我还要??乱痪渚咛迨窃趺锤銮榭?个人理解)
在RN中用findNodeHandle方法去获取ref控件的tag值,将这个值传入到iOS原生中,再用
利用这个tag获取当当前的view,根据view获取当前VC,用VC去跳转页面且传值使用.完成调用
高德导航的一些坑
1,用pod引入的是5.3.0版本,demo中确实5.5.0版本,方法少了很多,自己修改一下问题不大
2, iOS9以下会有内存泄漏问题,导致崩溃
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法