react-native v0.29.x 后 Android 平台部分插件无法使用的问题

Posted 木子飞

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了react-native v0.29.x 后 Android 平台部分插件无法使用的问题相关的知识,希望对你有一定的参考价值。

本文写给已经有RN封装android原生模块经验的童鞋们。如有疑问请查看官方文档这里

在老版本的注册模块的时候,如果模块的构造函数里有Activity参数,我们可以直接在括号里面加this,如图

 

从 v0.29.0 开始,Android 项目新增了 MainApplication.java 模板,大部分以前在 MainActivity.java 的逻辑迁移到了这里

Register module (in MainApplication.java)

import ca.jaysoo.extradimensions.ExtraDimensionsPackage;  // <--- import

public class MainApplication extends Application implements ReactApplication {

  ......

  protected List<ReactPackage> getPackages() {

    return Arrays.<ReactPackage>asList(

      new MainReactPackage(),

      new ExtraDimensionsPackage()  // <--- add here

    );

  }

  ......

}

上面只是代码位置迁移,只是 new 的时候少了 this 这个参数,因为这时候 this 已经不再是 current activity 了,这也是导致整个问题的重要原因!

 

因为 Current Activity 已经不再通过构造函数传递进来了,我们只能通过其他的方式尝试找回 Current Activity

那么在哪里呢?熟悉原生Android的朋友们应该知道,有一个上下文getCurrentActivity()方法,我们要用Activity的时候可以通过这个方法获取到。

那么答案已经呼之欲出了,没有错就是在我们创建模块的时候获取Activity

 

如图所示

0.29版本以前,这个OrientationModule的构造方法一般会在括号里直接加Activity参数,

public OrientationModule(ReactApplicationContext reactContext,Activity activity) {

        super(reactContext);

    }

然后在注册的时候加this,但是新版本不行啊,所以我们这里到出到js的方法里面如果需要用到Activity的地方

直接采用getCurrentyActivity()方法就行了,如图所示

到这里已经大功告成,剩下的就是基本的配置了,这里不再赘述

以上是关于react-native v0.29.x 后 Android 平台部分插件无法使用的问题的主要内容,如果未能解决你的问题,请参考以下文章

在应用程序安装后使用带有 react-native 的分支引用识别发件人

React-Native组件之 Navigator和NavigatorIOS

在react-native中,我如何在ios和android的图像上添加水印

在react-native 项目中使用yarn link

React-Native:Facebook 登录后返回应用程序?

React-Native添加依赖包后出现Native module cannot be null!的解决办法