在使用RN开发过程中,难免有些原生功能需要要自己来实现,下面总结一下在使用RN与原生开发交互。

1、在原生代码中定义实现类

  1.1  首先继承 ReactContextBaseJaveModule抽象类

    public class SomeModule extends ReactContextBaseJavaModule{}

  1.2  实现构造方法

    public SomeModule(ReactApplicationContext context){

      super(context);

    }

  1.3  实现 getName() 方法,并返回一个字符串

    @Override

    public String getName(){

      return "SomeModule"; //返回值将在RN代码中使用

    }

  1.4  实现功能方法,使用注解@ReactMethod修饰(使用修饰ReactMethod的方法,可以在RN中被调用)

    @ReactMethod

    public void callbackMethod(Object paramsFromJS,Callback ok,Callback error){

      //... do something , result = true

      if(result){

        ok.invoke("params");

      }else{

        error.invoke("error");

      }

    }

    @ReactMethod

    public void promiseMethod(Object paramsFromJS,Promise promise){

      // ... do something, result = true

      if(result){

        promise.resolve("params");

      }else{

        promise.reject("error");

      }

    }

2、原生注册模块

  2.1 注册模块

  实现ReactPackage接口

  public class SomeReactPackage implements ReactPackage{

    public List<NativeModule> createNativeModules(ReactApplicationContext reactContext){

      return Collections.<NativeModule>singletonList(new SomeModule(reactContext));

    }

    public List<ViewManager> createViewManagers(ReactApplicationContext reactContext) {

      return Collections.emptyList();

    }

    public List<Class<? extends JavaScriptModule>> createJSModules() {

      return Collections.emptyList();

    }

  }

  2.2  添加模块

    在MainPackage类的getPackages()方法中添加模块

    public List<ReactPackage> getPackages() {

      return Arrays.<ReactPackage>asList(new MainReactPackage(),new SomeReactPackage());

    }

3、RN中JS代码

  3.1  首先导入库

    import { NativeModules } from 'react-native'

  3.2  调用原生方法

    3.2.1回调方法

      NativeModules.SomeModule.callbackMethod('params',(ok)=>{},(error)=>{});

    3.2.2 Promise方法    

      NativeModules.SomeModule.promiseMethod('params').then((ok)=>{}).catch((error)=>{});

    3.2.3 说明

      NativeModules : 不用解释,react-native提供的类库

      SomeModule : 原生代码中,getName()方法返回字符串

      callbackMethod() / promiseMethod() : 原生代码中,使用@ReactMethod修饰的方法

      (ok)=>{} : 成功回调方法

      (error)=>{} : 失败回调方法

    

至此,RN与原生混合开发最基本的流程已经OK 。

RN开发-Android原生交互的更多相关文章

  1. (五)react-native开发系列之Android原生交互

    react-native可以做web与原生的交互,这是使用react-native开发项目的主要目的之一,也是主要优势,用rn而不用原生交互则毫无价值,这篇文章用来记录在项目中rn的原生交互使用过程. ...

  2. RN与android原生开发混合后的环境报错问题

    RN与android原生开发混合后的环境报错问题 需要先安装nodejs$ yarn --version1.12.1更新当前版本yarn upgrade --latest安装 | Yarnhttps: ...

  3. 像写Flutter一样开发Android原生应用

    要问到Flutter和Android原生App,在开发是有何区别,编程方式是绕不开的话题.Flutter采用声明式编程,Android原生开发则采用命令式编程. 声明式编程 VS. 命令式编程 我们首 ...

  4. js与android原生交互

    package com.liuhao.mysecond; import androidx.annotation.RequiresApi;import androidx.appcompat.app.Ap ...

  5. React Native Android原生模块开发实战|教程|心得|怎样创建React Native Android原生模块

    尊重版权,未经授权不得转载 本文出自:贾鹏辉的技术博客(http://blog.csdn.net/fengyuzhengfan/article/details/54691503) 告诉大家一个好消息. ...

  6. Android原生跳转React不同页面(undefined is not an object)

    继续上篇文章的demo,由于现在的项目是原生的,打算用部分页面试下react native,那么问题来了:react貌似只有一个入口 index.android.js,那么在不同的原生页面需要跳转到不 ...

  7. Android原生和H5交互;Android和H5混合开发;WebView点击H5界面跳转到Android原生界面。

    当时业务的需求是这样的,H5有一个活动商品列表的界面,IOS和Android共用这一个界面,点击商品可以跳转到Android原生的商品详情界面并传递商品ID:  大概就是点击H5界面跳转到Androi ...

  8. React-Native开发之原生模块封装(Android)升级版

     本文主题:如何实现原生代码的复用,即如何将原生模块封装. (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/52862 ...

  9. iOS原生混合RN开发最佳实践

    iOS原生混合RN开发详解 做过原生iOS开发或者Android开发的同学们肯定也都了解Hybrid,有一些Hybrid的开发经验,目前我们企业开发中运用最广泛的Hybrid App技术就是原生与H5 ...

随机推荐

  1. SpringBoot支持SpringData es

    ElasticSearch CRUD 1.springboot springData es spring data 是spring对数据访问抽象.这些数据可以放入db,index,nosql等包含以下 ...

  2. 为什么选择Spring Boot?

    本文概述了各种Spring配置样式,并帮助你了解配置Spring应用程序的复杂性.抽丝剥茧 细说架构那些事——[优锐课] Spring是一个非常流行的基于Java的框架,用于构建Web和企业应用程序. ...

  3. oracle 数据库 Cause: java.sql.SQLSyntaxErrorException: ORA-00904: "BODY": 标识符无效

    1.全大写或者加引号 SELECT TEST_NAME FROM T_TEST  或者 SELECT “test_name” from "t_user"

  4. 选择排序 C++实现

    实现思想: 1.寻找[i, n)区间里的最小值min ( i>= 0 ) 2.交换min和第i的数 ( i>= 0 ) #include <iostream> #include ...

  5. Anaconda切换工作目录盘符

    先回到C盘符的根目录再切换到其他盘符

  6. .Net Core通过json文件 配置管理后台导航菜单

    先来看个最终效果图 以前我们配置后台菜单 一般都是把菜单链接, 图标, 以及层级关系 配置到数据库,Core很容易通过json文件来配置导航菜单  而不用存数据库了 先添加个menuconfig.js ...

  7. java设计模式学习笔记--依赖倒转原则

    依赖倒转原则简述 1.高层模块不应该依赖低层模块,二者都应该依赖其抽象 2.抽象不应该依赖细节,细节应该依赖抽象 3.依赖倒转得中心思想时面向接口编程 4.依赖倒转原则时基于这样得设计理念:相对于细节 ...

  8. 纪中5日T1 1564. 旅游

    1564. 旅游 题目描述 输入N个数,从中选择一些出来计算出总和,问有多少种选法使得和为质数. 输入 第一行一个整数N. 第二行N个整数,表示这N个数的值. 输出 一个整数,表示方案数. 样例输入 ...

  9. 论文阅读笔记(二十)【AAAI2019】:Spatial and Temporal Mutual Promotion for Video-Based Person Re-Identification

    Introduction (1)Motivation: 作者考虑到空间上的噪声可以通过时间信息进行弥补,其原因为:不同帧的相同区域可能是相似信息,当一帧的某个区域存在噪声或者缺失,可以用其它帧的相同区 ...

  10. 卸载Windows控制面板的程序和功能中找不到的一些软件的方法

    卸载Windows控制面板的程序和功能中找不到的一些软件的方法 找到卸载程序进行卸载即可