资讯专栏INFORMATION COLUMN

react-native调用Native:回调(Android)

Euphoria / 1217人阅读

摘要:本身是事件驱动的语言,需在中可以使用回调方法来处理函数返回的结果。同样地在中定义了和的接口,用来处理调用方法的回调。是中增加的对于异步编程和回调更加友好的使用可以更简洁,更灵活地处理回调。

在react-native中可以通过在java层自定义ReactMethod(https://segmentfault.com/a/1190000004486024)方式给JavaScript调用,这样在JavaScript层就可以直接调用Android中的Native方法.
但在大部分的方法调用中,都需要知道调用方法之后的处理结果是什么,有没有出现异常等情况。JavaScript本身是事件驱动的语言,需在JavaScript中可以使用回调方法来处理函数返回的结果。同样地在react-native中定义了CallbackPromise的接口,用来处理JavaScript调用Java方法的回调。

Callback

Callback是react.bridge中的一个接口,它作为ReactMethod的一个传参,用来映射JavaScript的回调函数(function)。Callback接口只定义了一个方法invoke,invoke接受多个参数,这个参数必须是react.bridge中支持的参数。
首先我们定义一个类用来给JavaScript调用:

public class StoreModule extends ReactContextBaseJavaModule {

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

}

指定其名称为StoreModule
下面我们一定个方法,用来保存userNamepasswordShardPreferences中,在这个方法中,我们需要定义两个Callback参数,一个用来处理成功的情况,一个用来处理异常的情况。

    @ReactMethod
    public void addUser(String userName, String password, Callback successCallback, Callback errorCallback) {
        try {
            if (TextUtils.isEmpty(userName)) {
                errorCallback.invoke("user name is empty");
                return;
            }
            if (TextUtils.isEmpty(password)) {
                errorCallback.invoke("password is empty");
                return;
            }
            preferences.edit().putString(USER_NAME, userName).commit();
            preferences.edit().putString(PASSWORD, password).commit();
            successCallback.invoke("add user success");
        } catch (Exception e) {
            e.printStackTrace();
            errorCallback.invoke(e.getMessage());
        }
    }

现在我们有了一个带有Callback作为参数的StoreModule类,把这个类的实例加入ReactPackagecreateNativeModules中,就可以在JavaScript层调用该方法。
在JavaScript中,调用这个带有Callback参数的方法:

var {NativeModules}=require("react-native");
var storeModule=NativeModules.StoreModule;
storeModule.addUser("jjz","123456",(msg)=>{
    alert(msg);
  },(errorMsg)=>{
    alert(errorMsg)
});

这里的方法回调方法我们都是使用的匿名函数,在JavaScript调用Java之后,处理结果会以Callback的形式回到JavaScript中,在JavaScript中再对相应的结果进行处理。

Promise

Promise是ES6中增加的对于异步编程和回调更加友好的API(https://segmentfault.com/a/1190000004505028),使用Promise可以更简洁,更灵活地处理回调。
react.briage中定义的Promise接口,实现了resolvereject的方法,resolve用来处理正确处理结果的情况,reject用来处理异常的情况。
StoreModule定义一个支持Promise作为参数的方法:

    @ReactMethod
    public void login(String userName, String password, Promise promise) {
        String storeUserName = preferences.getString(USER_NAME, "");
        String storePassword = preferences.getString(PASSWORD, "");
        if (!equalsString(userName, storeUserName)) {
            promise.reject("0", "user name is wrong");
            return;

        }
        if (!equalsString(password, storePassword)) {
            promise.reject("1", "password is wrong");
            return;

        }
        WritableMap map = Arguments.createMap();
        map.putDouble("user_id", 1);
        promise.resolve(map);

    }

这里的WritableMap继承了ReadableMap,定义了Java和JavaScript中的参数转换.
调用这个方法的时候,在JavaScript中会返回一个Promise对象,这意味着你可以JavaScript直接使用。
在JavaScript中调用:

storeModule.login("jjz","123456").then((map)=>{
    alert(map["user_id"]);
  },(code,message)=>{
    alert(message);
})

使用Promise比使用Callback更加的简洁,还能更加灵活的在多线程之间进行切换。

代码地址:https://github.com/jjz/react-native/tree/master/RNJava

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/78778.html

相关文章

  • React-native 使用原生(ios, android)第三方sdk

    摘要:但阿里百川并没有提供直接获取数据的方法,所以选择时一定要慎重。 React-native 使用native第三方sdk ios(以阿里百川用户反馈为例) 首先安装cocopods(类似于npm,ios开发的依赖管理工具,教程:http://www.code4app.com/artic... 在ios根目录下创建Podfile文件,添加如下代码(使用的是百川feedback1.1.1版...

    qujian 评论0 收藏0
  • RN 技术探索:Hermes Engine 初探

    摘要:原方式中是经过压缩的脚本文件,预编译后则是二进制文件。两者影响叠加导致整体减小,包大小得到优化。引擎包引擎包官方文档中对内存区的描述您的应用用于处理代码和资源如字节码已优化或已编译的码库和字体的内存。本文首发自普惠出行产品技术 自从 Google 的 Flutter 发布之后,Facebook 对 React-Native 的迭代开始快了起来,优化 React-Native 的性能表现...

    Cc_2011 评论0 收藏0
  • React Native 中切换TextInput保持键盘展开

    摘要:传给回调函数的里,包含一个触摸事件参数。官网的版文档中,和组件中都有属性,这个属性接收一个回调函数,函数原型是,在组件和的组件的时候触发该事件,传给回调函数的里,参数,其中的属性为该组件的。 1、问题 问题场景: 由于手机屏幕高度不定,做表单页面时,外层通常加上ScrollView组件,使其能够适应屏幕进行滚动。业务需要里面放置多个TextInput组件。 问题描述: 出现的问题是,首...

    xiangzhihong 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<