cordova內(nèi)核優(yōu)化

問(wèn)題:

從研發(fā)cordova混編App開(kāi)發(fā)開(kāi)始,不同安卓版本手機(jī)上的兼容性問(wèn)題就困擾著研發(fā)的童鞋們。Cordova使用的web引擎是手機(jī)系統(tǒng)自帶的WebView,兼容性問(wèn)題很多都是安卓不同版本的系統(tǒng)webview的差異導(dǎo)致的,有可能是安卓系統(tǒng)的問(wèn)題,也有可能是手機(jī)廠商修改webkit帶來(lái)的問(wèn)題,這些問(wèn)題從前端技術(shù)層面是很難解決的,修改和測(cè)試成本都非常高。

瀏覽器內(nèi)核介紹

如果細(xì)分的話,目前全球僅有四個(gè)獨(dú)立的瀏覽器內(nèi)核,分別為微軟IE的Trident、網(wǎng)景最初研發(fā)后賣(mài)給Mozilla基金會(huì)并演化成火狐的Gecko、KDE的開(kāi)源內(nèi)核Webkit以及Opera(歐朋)的Presto。其中,Presto是歷史最悠久的內(nèi)核。

整體歸納下幾種內(nèi)核的優(yōu)缺點(diǎn)吧:

1.Trident:因?yàn)樵谠缙贗E占有大量的市場(chǎng)份額,所以以前有很多網(wǎng)頁(yè)是根據(jù)這個(gè)Trident的標(biāo)準(zhǔn)來(lái)編寫(xiě)的,但是實(shí)際上這個(gè)內(nèi)核對(duì)真正的網(wǎng)頁(yè)標(biāo)準(zhǔn)支持不是很好,同時(shí)存在許多安全Bug。
2.Gecko:優(yōu)點(diǎn)就是功能強(qiáng)大、豐富,可以支持很多復(fù)雜網(wǎng)頁(yè)效果和瀏覽器擴(kuò)展接口,缺點(diǎn)是消耗很多的資源,比如內(nèi)存。
3.Webkit:優(yōu)點(diǎn)就是Webkit擁有清晰的源碼結(jié)構(gòu)、極快的渲染速度,缺點(diǎn)是對(duì)網(wǎng)頁(yè)代碼的兼容性較低,會(huì)使一些編寫(xiě)不標(biāo)準(zhǔn)的網(wǎng)頁(yè)無(wú)法正確顯示。
4.Presto:Presto內(nèi)核被稱為公認(rèn)的瀏覽網(wǎng)頁(yè)速度最快的內(nèi)核,同時(shí)也是處理JS腳本最兼容的內(nèi)核,能在Windows、Mac及Linux操作系統(tǒng)下完美運(yùn)行。

移動(dòng)端瀏覽器

目前微軟的Trident在移動(dòng)終端上主要為WP系統(tǒng)內(nèi)置瀏覽器,Webkit內(nèi)核的適用范圍則較為廣泛,Android原生瀏覽器、蘋(píng)果的Safari、谷歌的Chrome(Android4.0使用)都是基于Webkit開(kāi)源內(nèi)核開(kāi)發(fā)的。
目前,移動(dòng)設(shè)備瀏覽器上常用的內(nèi)核有Webkit,Blink,Trident,Gecko等,其中iPhone和iPad等蘋(píng)果iOS平臺(tái)主要是WebKit,Android 4.4之前的Android系統(tǒng)瀏覽器內(nèi)核是WebKit,Android4.4系統(tǒng)瀏覽器切換到了Chromium(內(nèi)核是Webkit的分支Blink),Windows Phone 8系統(tǒng)瀏覽器內(nèi)核是Trident。

從實(shí)際情況出發(fā):

對(duì)于Android手機(jī)而言,使用率最高的就是Webkit內(nèi)核,我們看到很多手機(jī)瀏覽器廠商都宣稱有著自主內(nèi)核,比如手機(jī)UC就號(hào)稱采用了U3內(nèi)核、而華為也經(jīng)常標(biāo)榜自己的天天瀏覽器采用了T9內(nèi)核,事實(shí)上,他們都是基于開(kāi)源內(nèi)核Webkit進(jìn)行二次開(kāi)發(fā)的,并不是完全的自主內(nèi)核。
而在iOS以及WP7平臺(tái)上,由于系統(tǒng)封閉,不允許除系統(tǒng)自帶瀏覽器內(nèi)核以外的瀏覽器內(nèi)核進(jìn)入,因此各家瀏覽器的開(kāi)發(fā)均為在Safari或者IE內(nèi)核的基礎(chǔ)上進(jìn)行二次開(kāi)發(fā),優(yōu)化功能和自制UI。

微信6.1版本以上的android用戶,都是使用的QQ瀏覽器的X5內(nèi)核。5.4-6.1之間的版本,若用戶安裝了QQ瀏覽器就是使用的X5內(nèi)核,若用戶未安裝瀏覽器,使用的是系統(tǒng)內(nèi)核。
QQ瀏覽器的X5內(nèi)核基于 Blink內(nèi)核

cordova應(yīng)用內(nèi)核

Cordova(PhoneGap),作為第三方的HTML5應(yīng)用開(kāi)發(fā)框架工具的代表,極大促進(jìn)了HTML5應(yīng)用的發(fā)展。它提供了方便的跨平臺(tái)應(yīng)用打包/發(fā)布服務(wù)、實(shí)用的API、靈活的擴(kuò)展機(jī)制、以及積累下來(lái)的豐富的第三方API實(shí)現(xiàn)。然而Cordova使用的web引擎是系統(tǒng)的WebView。如果開(kāi)發(fā)者正在使用Cordova并且渴望更好的性能和更新的功能,如WebGL,更換內(nèi)核是個(gè)不錯(cuò)的選擇。

終極解決方案

通過(guò)使用統(tǒng)一webkit內(nèi)核的大招來(lái)解決,目前有2個(gè)方案可選,使用Crosswalk內(nèi)核 或 騰訊瀏覽服務(wù)X5內(nèi)核。

1.Crosswalk內(nèi)核

熟悉Cordova生態(tài)圈的朋友可能聽(tīng)說(shuō)過(guò)Crosswalk,[Crosswalk]是Intel維護(hù)的Webkit開(kāi)源項(xiàng)目,可以通過(guò)插件安裝命令安裝,是一個(gè)很好的選擇。

$ cordova plugin add cordova-plugin-crosswalk-webview

Crosswalk支持開(kāi)發(fā)者在Cordova中用Crosswalk替換原生的Android WebView,并將兩者完美的融合。當(dāng)然,它仍然支持Crodova的擴(kuò)展機(jī)制,不過(guò)如果web應(yīng)用對(duì)擴(kuò)展的性能要求較高, 采用Crosswalk自帶的擴(kuò)展機(jī)制是更好的選擇。
它的缺點(diǎn)就是太大了,集成后apk會(huì)增加20M,在安裝后會(huì)解壓縮到100M+,首次安裝還需要解壓縮時(shí)間,造成的用戶體驗(yàn)甚是不好。一系列的問(wèn)題就跟著來(lái)了,解壓縮需要時(shí)間,如果操作快了,或者CPU性能不行,打開(kāi)Hybrid頁(yè)面就會(huì)出現(xiàn)Application Error等問(wèn)題。還有些機(jī)型如魅族,安裝Crosswalk后,就會(huì)Crash,讓研發(fā)的童鞋更是摸不著頭腦。

不過(guò)在我做過(guò)的兩個(gè)app中,確實(shí)是通過(guò)Crosswalk解決了一些魅族和華為的問(wèn)題,也出現(xiàn)過(guò)報(bào)錯(cuò)App打開(kāi)失?。ㄖ怀霈F(xiàn)過(guò)一次)

2.騰訊瀏覽服務(wù)X5內(nèi)核。

騰訊瀏覽服務(wù)X5,它是直接使用微信/手機(jī)QQ/空間的X5瀏覽器內(nèi)核的,SDK只有250k,因此可以放心使用。鑒于這幾個(gè)產(chǎn)品國(guó)內(nèi)廣泛的裝機(jī)量,用戶覆蓋方面不用擔(dān)心,如果微信/手機(jī)QQ/空間都沒(méi)有安裝,會(huì)自動(dòng)降級(jí)到系統(tǒng)瀏覽器內(nèi)核,或提示用戶安裝X5內(nèi)核。

X5SDK是通過(guò)調(diào)用微信/手機(jī)QQ/空間的X5內(nèi)核,解決系統(tǒng)webview兼容性差、加載速度慢、功能缺陷等問(wèn)題,開(kāi)發(fā)接入便捷,大小只有253K,僅需幾行代碼,即可解決一切令開(kāi)發(fā)者們頭疼的問(wèn)題,為用戶提供最優(yōu)秀的瀏覽體驗(yàn)。

同時(shí),QQ瀏覽器團(tuán)隊(duì)還將持續(xù)更新和優(yōu)化X5內(nèi)核,持續(xù)優(yōu)化功能,并保證兼容各種web新特性。
其相對(duì)于系統(tǒng)webview,具有下述明顯優(yōu)勢(shì):

  1. 速度快:相比系統(tǒng)webView的網(wǎng)頁(yè)加載速度有近30%的提升。
  2. 省流量:云端優(yōu)化技術(shù)使流量節(jié)省20%
  3. 更安全:24小時(shí)安全問(wèn)題解決機(jī)制
  4. 更穩(wěn)定:經(jīng)過(guò)億級(jí)用戶的使用考驗(yàn),CRASH率0.15%
  5. 集成強(qiáng)大的視頻播放器,支持各種視頻格式直接打開(kāi)
  6. 適屏排版、字體設(shè)置等瀏覽增強(qiáng)功能的提供
  7. Html5更完整支持。
  8. 無(wú)系統(tǒng)內(nèi)核的碎片化問(wèn)題,更少的兼容性問(wèn)題

X5內(nèi)核支持Cordova啦

Add this plugin

$ cordova plugin add cordova-plugin-x5-webview

Build

$ cordova build android
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,321評(píng)論 6 543
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,559評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事?!?“怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 178,442評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 63,835評(píng)論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,581評(píng)論 6 412
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 55,922評(píng)論 1 328
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,931評(píng)論 3 447
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 43,096評(píng)論 0 290
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,639評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,374評(píng)論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,591評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,104評(píng)論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,789評(píng)論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 35,196評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 36,524評(píng)論 1 295
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,322評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,554評(píng)論 2 379

推薦閱讀更多精彩內(nèi)容