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

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

Callback

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

public class StoreModule extends ReactContextBaseJavaModule {

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

}

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

@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参数的方法:github

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做为参数的方法:segmentfault

@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中调用:react-native

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

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

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

相关文章
相关标签/搜索