react-native常用插件
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了react-native常用插件相关的知识,希望对你有一定的参考价值。
参考技术A 顶部tab切换:npm install @react-navigation/material-top-tabs react-native-tab-viewreact-native-shadow
react-native-linear-gradient
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常用插件的主要内容,如果未能解决你的问题,请参考以下文章