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

在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://segmentfault.com/a/1190000004508328
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞