ReactNative项目从0.28升级到0.29(Android)

ReactNative项目从0.28升级到0.29 (Android)


备忘纪要:


1.升级react-native到0.29.0版本 

到项目跟目录下,cmd运行命令: react-native-git-upgrade 0.29.0,运行完毕后,应该没有ERROR类型的消息,会有一些提示信息:需要修改等等,表示react-native升级成功。

参考文章:http://blog.csdn.net/jiangbo_phd/article/details/54693335

注意: react-native-git-upgrade 0.29.0命令执行完毕后,会自动把之前的某些第三方的插件删除(node_modules目录下),具体原因未知,从原来的备份的文件中将丢失的模块拷贝到升级后的项目中既可。


2. 升级项目Android主程序文件

2.1 添加MainApplication.java文件,及相关内容

2.2 改造MainActivity.java文件,保留函数getMainComponentName(),将函数getPackages()及内容移动到文件MainApplication.java中

2.3 在 AndroidManifest.xml中将MainApplication文件设为启动文件

2.4 在项目的android目录下执行./gradlew clean,清理debug文件


具体操作参考如下:

https://github.com/facebook/react-native/releases/tag/v0.29.0

Android


3. 改造将Activity当做参数传到类中的第三方插件

.29版本之前的很多第三方的插件都是在MainActvity的getPackages函数中,直接将MainActivity自身传给第三方插件的初始化类,但是0.29版本开始不允许直接传入Activity对象,只能通过接口ReactContextBaseJavaModule的函数getCurrentActivity()来获取。

参考文档:

https://github.com/facebook/react-native/issues/8509#issuecomment-229719827

https://github.com/facebook/react-native/commit/49f20f41546e3ba8e7fe43c84c4c701684d0434d


处理方案:以react-native-datetime为例(https://github.com/cnjon/react-native-datetime)


3.1 将第三方插件的类实现接口LifecycleEventListener

public class RCTDateTimePicker extends ReactContextBaseJavaModule implements LifecycleEventListener {

3.2 在构造函数中添加监听接口LifecycleEventListener

public RCTDateTimePicker(ReactApplicationContext reactContext) {
    super(reactContext);
    reactContext.addLifecycleEventListener(this);
}

3.3 在具体需要调用Activity的函数中通过getCurrentActivity()获取Activity

    @ReactMethod
    public void showDatePicker(ReadableMap options, Callback callback) {
        Activity activity = getCurrentActivity();
        DialogFragment datePicker = new DatePicker(options, callback);
        datePicker.show(activity.getFragmentManager(), "datePicker");
    }

    @ReactMethod
    public void showTimePicker(ReadableMap options, Callback callback) {
        Activity activity = getCurrentActivity();
        DialogFragment timePicker = new TimePicker(options, callback);
        timePicker.show(activity.getFragmentManager(), "timePicker");
    }

    @ReactMethod
    public void showDateTimePicker(ReadableMap options, Callback callback) {
        Activity activity = getCurrentActivity();
        DialogFragment datetimePicker = new DateTimePicker(options, callback);
        datetimePicker.show(activity.getFragmentManager(), "datetimePicker");
    }

3.4 override函数onhostresume, onhostpause, onhostdestroy

    @Override
    public void onHostResume() {
    }

    @Override
    public void onHostPause() {
    }

    @Override
    public void onHostDestroy() {
    }


修改后的RCTDateTimePicker.java文件内容如下:


package com.keyee.datetime;

import android.app.Activity;
import android.app.DialogFragment;

import com.facebook.react.bridge.ReactApplicationContext;
import com.facebook.react.bridge.ReactContextBaseJavaModule;
import com.facebook.react.bridge.ReactMethod;
import com.facebook.react.bridge.Callback;
import com.facebook.react.bridge.ReadableMap;
import com.facebook.react.bridge.LifecycleEventListener;

public class RCTDateTimePicker extends ReactContextBaseJavaModule implements LifecycleEventListener {

    public RCTDateTimePicker(ReactApplicationContext reactContext) {
        super(reactContext);
        reactContext.addLifecycleEventListener(this);
    }
    @Override
    public void onHostResume() {
    }

    @Override
    public void onHostPause() {
    }

    @Override
    public void onHostDestroy() {
    }

    @Override
    public String getName() {
        return "DateTimePicker";
    }

    @ReactMethod
    public void showDatePicker(ReadableMap options, Callback callback) {
        Activity activity = getCurrentActivity();
        DialogFragment datePicker = new DatePicker(options, callback);
        datePicker.show(activity.getFragmentManager(), "datePicker");
    }

    @ReactMethod
    public void showTimePicker(ReadableMap options, Callback callback) {
        Activity activity = getCurrentActivity();
        DialogFragment timePicker = new TimePicker(options, callback);
        timePicker.show(activity.getFragmentManager(), "timePicker");
    }

    @ReactMethod
    public void showDateTimePicker(ReadableMap options, Callback callback) {
        Activity activity = getCurrentActivity();
        DialogFragment datetimePicker = new DateTimePicker(options, callback);
        datetimePicker.show(activity.getFragmentManager(), "datetimePicker");
    }
}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值