1、前言
经过前面两篇文章的实践,我们学习了Weex的使用。本篇开始我们深入Weex的源码,一起探索Weex在安卓平台上是如何构建一套JS的运行框架,那从Module开始说起吧。
本文从源码入手分析Module的注册、调用、回调等流程,并且分析一个Weex自带Module的实现。
在《Android 扩展》中我们可以看到Module的定位:
Module 扩展非UI的特定功能,例如 sendHttp、openURL 等。
也就是说是非UI类型的功能提供,在本地注册供Js运行时调用,有了Module,我们就可以自己扩展一些Weex没有提供的能力给Js,让Js更加强大!
还记不记得在上两篇文章中我们就用到了Module来实现网络请求的能力,声明+调用即完成了网络请求的调用;
var stream = weex.requireModule('stream') // 声明
stream.fetch // 请求
对于注册,也分为本地注册和Js注册:
备注:注册的意义在于Js与Native定义了一个协议,一个对应关系;调用的时候能找到Module。
调用分析:
调用分析:
Module的源码并不复杂:
分析了Module的注册、调用、回调等步骤,我们就来实例分析一个Weex中自带的Module:WXStreamModule,我们网络请求的功能就是它实现的,在Weex代码中我们调用网络请求的是fetch方法,那么我们在WXStreamModule方法中寻找fetch方法:
@JSMethod(uiThread = false)
public void fetch(String optionsStr, final JSCallback callback, JSCallback progressCallback){
......
String method = optionsObj.getString("method");
String url = optionsObj.getString("url");
JSONObject headers = optionsObj.getJSONObject("headers");
String body = optionsObj.getString("body");
String type = optionsObj.getString("type");
int timeout = optionsObj.getIntValue("timeout");
sendRequest()
......
}
public class DefaultWXHttpAdapter implements IWXHttpAdapter {
private ExecutorService mExecutorService = Executors.newFixedThreadPool(3);
@Override
public void sendRequest(final WXRequest request, final OnHttpListener listener) {
HttpURLConnection connection = openConnection(request, listener);
}
}
备注:通过细看WXStreamModule的源码我们不难发现最终网络请求的默认执行类DefaultWXHttpAdapter有一定缺陷,固定线程数的线程池实际上并不适合网络请求的场景,尤其在网络请求密集的场景下(整个模块、甚至应用都使用Weex来做,这种场景不会罕见)。因此如果我们要大面积使用Weex最好自己实现IWXHttpAdapter或者调用Native的方法。这是看源码的另一好处:从源码角度分析框架实现的利弊,定制更适合自己业务的实现。
自定义Module比较简单,就不在本文细说了,可以参照官方文档或者自带的Module的实现,也可以参考我写的WeexList,里面有自定义Module的使用。
欢迎持续关注Weex源码分析项目:Weex-Analysis-Project