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

前端之家收集整理的这篇文章主要介绍了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调用:

  1. public class StoreModule extends ReactContextBaseJavaModule {
  2.  
  3. @Override
  4. public String getName() {
  5. return "StoreModule";
  6. }
  7.  
  8. }

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

  1. @ReactMethod
  2. public void addUser(String userName,String password,Callback successCallback,Callback errorCallback) {
  3. try {
  4. if (TextUtils.isEmpty(userName)) {
  5. errorCallback.invoke("user name is empty");
  6. return;
  7. }
  8. if (TextUtils.isEmpty(password)) {
  9. errorCallback.invoke("password is empty");
  10. return;
  11. }
  12. preferences.edit().putString(USER_NAME,userName).commit();
  13. preferences.edit().putString(PASSWORD,password).commit();
  14. successCallback.invoke("add user success");
  15. } catch (Exception e) {
  16. e.printStackTrace();
  17. errorCallback.invoke(e.getMessage());
  18. }
  19. }

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

  1. var {NativeModules}=require('react-native');
  2. var storeModule=NativeModules.StoreModule;
  3. storeModule.addUser("jjz","123456",(msg)=>{
  4. alert(msg);
  5. },(errorMsg)=>{
  6. alert(errorMsg)
  7. });

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

Promise

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

  1. @ReactMethod
  2. public void login(String userName,Promise promise) {
  3. String storeUserName = preferences.getString(USER_NAME,"");
  4. String storePassword = preferences.getString(PASSWORD,"");
  5. if (!equalsString(userName,storeUserName)) {
  6. promise.reject("0","user name is wrong");
  7. return;
  8.  
  9. }
  10. if (!equalsString(password,storePassword)) {
  11. promise.reject("1","password is wrong");
  12. return;
  13.  
  14. }
  15. WritableMap map = Arguments.createMap();
  16. map.putDouble("user_id",1);
  17. promise.resolve(map);
  18.  
  19. }

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

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

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

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

猜你在找的React相关文章