Hybird调研

一、Cordova

  1. 不用第三方框架实现JS和Native交互

Native调用JS方式有

方式1: webView.evaluateJavascript(js, callback);

方式2: webView.loadUrl("javascript:" + js);

而这两种方式的实现,实际上都可以在Cordova框架的SystemWebView.java文件中找到。

而JS调用Native的方式有

方式1:通过addJavascriptInterface方法结合@JavascriptInterface注释来实现;

方式2:通过WebChromeClient对象,中的三个方法(onJsAlert,onJsConfirm,onJsPrompt)来实现;

当JS调用window对象的对应的方法,即window.alert,window.confirm,window.prompt,WebChromeClient对象中的三个方法对应的就会被触发, 于是可以利用这个机制实现JS调用Native方法。

  1. 插件模块初始化,并由clobber映射到对应的plugin.js

这个小节题目可能说的有点模糊,以MathPlugin的实现为例来解释下吧,,其plugin.xml有一段配置为

<js-module name="mymath" src="www/MathPlugin.js">
    <clobbers target="cordova.plugins.math"/>
</js-module>

同时我们定义了一个MathPlugin.js文件来调用原生代码

var exec = require('cordova/exec');
var myMathFunc = function(){};  

myMathFunc.prototype.plus = function(success, error, arg0) {
    exec(success, error, "MathPlugin", "plus", arg0);
};

myMathFunc.prototype.minus = function(success, error, arg0) {
    exec(success, error, "MathPlugin", "minus", arg0);
};

var MYMATHFUNC = new myMathFunc();
module.exports = MYMATHFUNC; 

并且当时说在js中直接通过cordova.plugins.math.plus便可调用到MathPlugin.js文件中plus扩展方法,那么这中间便存在一个clobber和plugin.js之间的映射过程
cordova.js在App启动时,首先从cordova_plugin.js中加载插件,并存放在本地变量中,接着在channel.join方法中创建cordova相关所有对象模块,其中也包括了插件所对相应的对象模块(这里指MathPlugin.js),接着再通过后面几个方法来处理映射关系,经过一系列的操作后,会将cordova_plugin.js文件中的clobber:cordova.plugin.math和MathPlugin.js中的myMathFunc行程一一对应关系,之后就可以通过cordova.plugin.math.plus调用myMathFunc模块中的plus方法了。

  1. 插件JS代码如何调用到了Native代码

第一小节提到了Android实际上是提供了两种JS代码调用Native代码的方式的,而Corodva插件实现JS代码调用Native代码的方法正是通过这两种方式实现的,不过在用着两种方式之前经历了一系列的其它操作

image.png

从图中可以看出当调用cordova.plugin.math.plus方法时,会调用到exec.js模块的androidExec方法,并在该方法中会生成一个callbackId参数,该参数格式是由plugin名称+变化的数字(每次加一)组成,比如callbackId = MathPlugin123487,这个参数是唯一的,在js调用native时会传到naive代码,当native代码返回时,又会把这个参数返回js,这样js就能够判断返回参数对应的插件模块了,再根据success和error方法便能够输出native端返回js端的数据。
之后会调用nativeApiProvidet.get()方法,而返回的nativeApi实际上是

var nativeApi = this._cordovaNative || require('cordova/android/promptbasednativeapi');

这里有个this._cordovaNative表示webView是否有设置

webView.addJavascriptInterface(exposedJsApi, "_cordovaNative");

如果设置了,则执行nativeApiProvider.get().exec方法后就会执行exposedJsApi.java里的相应方法; 如果没有设置,那么就调用 platform_www/cordova-js-src/android/promptbasednativeapi.js里exec方法,该方法是执行 js的prompt方法(这个是一个常用的jsbridge里通信方法),之后就会执行WebChromClient的onJsPrompt方法。

  1. CallBackContext对象调用JS代码


    image.png

    这里看看CordovaWebViewImpl中的sendPluginResult代码

@Override
public void sendPluginResult(PluginResult cr, String callbackId) {
    nativeToJsMessageQueue.addPluginResult(cr, callbackId);
}

贴出这个代码是为了强调下这里的callbackId,然后会将PluginResult数据存放在nativeToJsMessageQueue队列中。
所有的Native到JS的通信在Cordova中都是通过BrideMode来完成的,而BridgeMode在NativeToJsMessageQueue类中又三种实现方式

/** Uses webView.loadUrl("javascript:") to execute messages. */
方式1:public static class LoadUrlBridgeMode extends BridgeMode

/** Uses online/offline events to tell the JS when to poll for messages. */
方式2:public static class OnlineEventsBridgeMode extends BridgeMode

/** Uses webView.evaluateJavascript to execute messages. */
方式3:public static class EvalBridgeMode extends BridgeMode

其中LoadUrlBridgeMode对应

engine.loadUrl("javascript:" + js, false);

EvalBridgeMode 对应

engine.evaluateJavascript(js, null);

而OnlineEventsBridgeMode 这种模式对应

delegate.setNetworkAvailable(true);

二、VasSonic
根本目标是让webview的加载速度变快
当App首次打开时,默认是并不初始化浏览器内核的,只有当创建WebView实例的时候,才会创建WebView的基础框架。所以与浏览器不同,App中打开WebView的第一步并不是建立连接,而是启动浏览器内核,所以和电脑浏览器对比的话,第一个慢就体现在浏览器内核初始化上,也就是说我们第一次启动程序,调用loadUrl()方法的时候,会先初始化浏览器内核,而后才会从服务器获取界面到本地,并进行渲染(渲染其实就是解析(把html,css,js全部加载到本地解析出dom树,然后最后画到屏幕上)),大体的步骤如:DOM下载→DOM解析→CSS请求+下载→CSS解析→渲染→绘制→合成,如果js脚本放置位置不当或过于繁琐的话,也会堵塞并影响渲染的时间。
最终合成之后才会回调WebViewClient的onPageFinished方法。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,284评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,115评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,614评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,671评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,699评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,562评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,309评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,223评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,668评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,859评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,981评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,705评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,310评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,904评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,023评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,146评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,933评论 2 355

推荐阅读更多精彩内容