在react-native中能够经过在java层自定义ReactMethod
(https://segmentfault.com/a/1190000004486024)方式给JavaScript调用,这样在JavaScript层就能够直接调用Android中的Native方法.
但在大部分的方法调用中,都须要知道调用方法以后的处理结果是什么,有没有出现异常等状况。JavaScript自己是事件驱动的语言,需在JavaScript中能够使用回调方法来处理函数返回的结果。一样地在react-native中定义了Callback
和Promise
的接口,用来处理JavaScript调用Java方法的回调。java
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。
下面咱们必定个方法,用来保存userName和password到ShardPreferences
中,在这个方法中,咱们须要定义两个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类,把这个类的实例加入ReactPackage
的createNativeModules
中,就能够在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是ES6
中增长的对于异步编程和回调更加友好的API(https://segmentfault.com/a/1190000004505028),使用Promise能够更简洁,更灵活地处理回调。
在react.briage
中定义的Promise
接口,实现了resolve
和reject
的方法,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多线程