欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

React-Native 桥接iOS原生开发详解

程序员文章站 2023-12-19 11:50:40
react-native的文档的原生模块中可以看到清洗的代码 接下来先说一下笔者的要实现的功能: 在ios原生代码中集成高德导航,在rn中用js去调用原声...

react-native的文档的原生模块中可以看到清洗的代码

React-Native 桥接iOS原生开发详解

接下来先说一下笔者的要实现的功能:

在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以下会有内存泄漏问题,导致崩溃

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

上一篇:

下一篇: