一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

主流瀏覽器內(nèi)核介紹(前端開發(fā)值得了解的瀏覽器內(nèi)核歷史)

 wuday8 2016-01-11

內(nèi)核


首先得搞懂瀏覽器內(nèi)核究竟指的是什么。

瀏覽器內(nèi)核又可以分成兩部分:渲染引擎(layout engineer 或者 Rendering Engine)和 JS 引擎。它負(fù)責(zé)取得網(wǎng)頁的內(nèi)容(HTML、XML、圖像等等)、整理訊息(例如加入 CSS 等),以及計算網(wǎng)頁的顯示方式,然后會輸出至顯示器或打印機(jī)。瀏覽器的內(nèi)核的不同對于網(wǎng)頁的語法解釋會有不同,所以渲染的效果也不相同。所有網(wǎng)頁瀏覽器、電子郵件客戶端以及其它需要編輯、顯示網(wǎng)絡(luò)內(nèi)容的應(yīng)用程序都需要內(nèi)核。JS 引擎則是解析 Javascript 語言,執(zhí)行 javascript 語言來實(shí)現(xiàn)網(wǎng)頁的動態(tài)效果。

最開始渲染引擎和 JS 引擎并沒有區(qū)分的很明確,后來 JS 引擎越來越獨(dú)立,內(nèi)核就傾向于只指渲染引擎。有一個網(wǎng)頁標(biāo)準(zhǔn)計劃小組制作了一個 ACID 來測試引擎的兼容性和性能。內(nèi)核的種類很多,如加上沒什么人使用的非商業(yè)的免費(fèi)內(nèi)核,可能會有 10 多種,但是常見的瀏覽器內(nèi)核可以分這四種:Trident、Gecko、Blink、Webkit。

Trident (['tra?d(?)nt])


Trident(IE內(nèi)核):該內(nèi)核程序在 1997 年的 IE4 中首次被采用,是微軟在 Mosaic(”馬賽克”,這是人類歷史上第一個瀏覽器,從此網(wǎng)頁可以在圖形界面的窗口瀏覽) 代碼的基礎(chǔ)之上修改而來的,并沿用到 IE11,也被普遍稱作 “IE內(nèi)核”。

Trident實(shí)際上是一款開放的內(nèi)核,其接口內(nèi)核設(shè)計的相當(dāng)成熟,因此才有許多采用 IE 內(nèi)核而非 IE 的瀏覽器(殼瀏覽器)涌現(xiàn)。由于 IE 本身的 “壟斷性”(雖然名義上 IE 并非壟斷,但實(shí)際上,特別是從 Windows 95 年代一直到 XP 初期,就市場占有率來說 IE 的確借助 Windows 的東風(fēng)處于 “壟斷” 的地位)而使得 Trident 內(nèi)核的長期一家獨(dú)大,微軟很長時間都并沒有更新 Trident 內(nèi)核,這導(dǎo)致了兩個后果——一是 Trident 內(nèi)核曾經(jīng)幾乎與 W3C 標(biāo)準(zhǔn)脫節(jié)(2005年),二是 Trident 內(nèi)核的大量 Bug 等安全性問題沒有得到及時解決,然后加上一些致力于開源的開發(fā)者和一些學(xué)者們公開自己認(rèn)為 IE 瀏覽器不安全的觀點(diǎn),也有很多用戶轉(zhuǎn)向了其他瀏覽器,F(xiàn)irefox 和 Opera 就是這個時候興起的。非 Trident 內(nèi)核瀏覽器的市場占有率大幅提高也致使許多網(wǎng)頁開發(fā)人員開始注意網(wǎng)頁標(biāo)準(zhǔn)和非 IE瀏覽器的瀏覽效果問題。

補(bǔ)充:IE 從版本 11 開始,初步支持 WebGL 技術(shù)。IE8 的 JavaScript 引擎是 Jscript,IE9 開始用 Chakra,這兩個版本區(qū)別很大,Chakra 無論是速度和標(biāo)準(zhǔn)化方面都很出色。

國內(nèi)很多的雙核瀏覽器的其中一核便是 Trident,美其名曰 “兼容模式”。

Window10 發(fā)布后,IE 將其內(nèi)置瀏覽器命名為 Edge,Edge 最顯著的特點(diǎn)就是新內(nèi)核 EdgeHTML。關(guān)于 Edge 瀏覽器更多可以參考 如何評價 Microsoft Edge 瀏覽器?

Gecko (['gek??])


Gecko(Firefox 內(nèi)核):Netscape6 開始采用的內(nèi)核,后來的 Mozilla FireFox(火狐瀏覽器) 也采用了該內(nèi)核,Gecko 的特點(diǎn)是代碼完全公開,因此,其可開發(fā)程度很高,全世界的程序員都可以為其編寫代碼,增加功能。因為這是個開源內(nèi)核,因此受到許多人的青睞,Gecko 內(nèi)核的瀏覽器也很多,這也是 Gecko 內(nèi)核雖然年輕但市場占有率能夠迅速提高的重要原因。

事實(shí)上,Gecko 引擎的由來跟 IE 不無關(guān)系,前面說過 IE 沒有使用 W3C 的標(biāo)準(zhǔn),這導(dǎo)致了微軟內(nèi)部一些開發(fā)人員的不滿;他們與當(dāng)時已經(jīng)停止更新了的 Netscape 的一些員工一起創(chuàng)辦了 Mozilla,以當(dāng)時的 Mosaic 內(nèi)核為基礎(chǔ)重新編寫內(nèi)核,于是開發(fā)出了 Gecko。不過事實(shí)上,Gecko 內(nèi)核的瀏覽器仍然還是 Firefox (火狐) 用戶最多,所以有時也會被稱為 Firefox 內(nèi)核。此外 Gecko 也是一個跨平臺內(nèi)核,可以在Windows、 BSD、Linux 和 Mac OS X 中使用。

Webkit


一提到 webkit,首先想到的便是 chrome,可以說,chrome 將 Webkit內(nèi)核 深入人心,殊不知,Webkit 的鼻祖其實(shí)是 Safari?,F(xiàn)在很多人錯誤地把 webkit 叫做 chrome內(nèi)核(即使 chrome內(nèi)核已經(jīng)是 blink 了),蘋果都哭瞎了有木有。

Safari 是蘋果公司開發(fā)的瀏覽器,使用了KDE(Linux桌面系統(tǒng))的 KHTML 作為瀏覽器的內(nèi)核,Safari 所用瀏覽器內(nèi)核的名稱是大名鼎鼎的 WebKit。 Safari 在 2003 年 1 月 7 日首度發(fā)行測試版,并成為 Mac OS X v10.3 與之后版本的默認(rèn)瀏覽器,也成為蘋果其它系列產(chǎn)品的指定瀏覽器(也已支持 Windows 平臺)。

如上述可知,WebKit 前身是 KDE 小組的 KHTML 引擎,可以說 WebKit 是 KHTML 的一個開源的分支。當(dāng)年蘋果在比較了 Gecko 和 KHTML 后,選擇了后者來做引擎開發(fā),是因為 KHTML 擁有清晰的源碼結(jié)構(gòu)和極快的渲染速度。

Webkit內(nèi)核 可以說是以硬件盈利為主的蘋果公司給軟件行業(yè)的最大貢獻(xiàn)之一。隨后,2008 年谷歌公司發(fā)布 chrome 瀏覽器,采用的 chromium 內(nèi)核便 fork 了 Webkit。

Chromium/Bink


2008 年,谷歌公司發(fā)布了 chrome 瀏覽器,瀏覽器使用的內(nèi)核被命名為 chromium。

chromium fork 自開源引擎 webkit,卻把 WebKit 的代碼梳理得可讀性提高很多,所以以前可能需要一天進(jìn)行編譯的代碼,現(xiàn)在只要兩個小時就能搞定。因此 Chromium 引擎和其它基于 WebKit 的引擎所渲染頁面的效果也是有出入的。所以有些地方會把 chromium 引擎和 webkit 區(qū)分開來單獨(dú)介紹,而有的文章把 chromium 歸入 webkit 引擎中,都是有一定道理的。

谷歌公司還研發(fā)了自己的 Javascript 引擎,V8,極大地提高了 Javascript 的運(yùn)算速度。

chromium 問世后,帶動了國產(chǎn)瀏覽器行業(yè)的發(fā)展。一些基于 chromium 的單核,雙核瀏覽器如雨后春筍般拔地而起,例如 搜狗、360、QQ瀏覽器等等,無一不是套著不同的外殼用著相同的內(nèi)核。

然而 2013 年 4 月 3 日,谷歌在 Chromium Blog 上發(fā)表 博客,稱將與蘋果的開源瀏覽器核心 Webkit 分道揚(yáng)鑣,在 Chromium 項目中研發(fā) Blink 渲染引擎(即瀏覽器核心),內(nèi)置于 Chrome 瀏覽器之中。

webkit 用的好好的,為何要投入到一個新的內(nèi)核中去呢?

Blink 其實(shí)是 WebKit 的分支,如同 WebKit 是 KHTML 的分支。Google 的 Chromium 項目此前一直使用 WebKit(WebCore) 作為渲染引擎,但出于某種原因,并沒有將其多進(jìn)程架構(gòu)移植入Webkit。

后來,由于蘋果推出的 WebKit2 與 Chromium 的沙箱設(shè)計存在沖突,所以 Chromium 一直停留在 WebKit,并使用移植的方式來實(shí)現(xiàn)和主線 WebKit2 的對接。這增加了 Chromium 的復(fù)雜性,且在一定程度上影響了 Chromium 的架構(gòu)移植工作。

基于以上原因,Google 決定從 WebKit 衍生出自己的 Blink 引擎(后由 Google 和 Opera Software 共同研發(fā)),將在 WebKit 代碼的基礎(chǔ)上研發(fā)更加快速和簡約的渲染引擎,并逐步脫離 WebKit 的影響,創(chuàng)造一個完全獨(dú)立的 Blink 引擎。這樣以來,唯一一條維系 Google 和蘋果之間技術(shù)關(guān)系的紐帶就這樣被切斷了。

Google 和蘋果在多個領(lǐng)域都是競爭對手,而唯獨(dú)在瀏覽器引擎上有技術(shù)合作,利益一致。但為了各自的利益,誰都不會拿出 100% 的 “誠意” 來做好 WebKit,因為你做出來的成果競爭對手可以直接享用。移動互聯(lián)網(wǎng)已經(jīng)崛起,手機(jī)和平板設(shè)備端必將成為瀏覽器的另一個戰(zhàn)場。這個時候,如果 Google 跟蘋果仍然黏在一起,將會嚴(yán)重阻礙雙方的進(jìn)步,也會阻礙 WebKit 的進(jìn)步。

據(jù)說 Blink 刪除了 880w 行 webkit 代碼。

至于為什么叫 blink?有興趣的可以看下這篇訪談 Paul Irish on Chrome Moving to Blink,里面說

1
it fits that Blink will never support the infamous <blink> tag.

Blink 引擎問世后,國產(chǎn)各種 chrome 系的瀏覽器也紛紛投入 Blink 的懷抱,可以在瀏覽器地址欄輸入 chrome://version 進(jìn)行查看。比如在 360 下:

Presto (['prest??])


Presto 是挪威產(chǎn)瀏覽器 opera 的 “前任” 內(nèi)核,為何說是 “前任”,因為最新的 opera 瀏覽器早已將之拋棄從而投入到了谷歌大本營。

Opera 的一個里程碑作品是 Opera7.0,因為它使用了 Opera Software 自主開發(fā)的 Presto 渲染引擎,取代了舊版 Opera 4 至 6 版本使用的 Elektra 排版引擎。該款引擎的特點(diǎn)就是渲染速度的優(yōu)化達(dá)到了極致,然而代價是犧牲了網(wǎng)頁的兼容性。

Presto 加入了動態(tài)功能,例如網(wǎng)頁或其部分可隨著 DOM 及 Script 語法的事件而重新排版。Presto 在推出后不斷有更新版本推出,使不少錯誤得以修正,以及閱讀 Javascript 效能得以最佳化,并成為當(dāng)時速度最快的引擎。

然而為了減少研發(fā)成本,Opera 在 2013 年 2 月宣布放棄 Presto,轉(zhuǎn)而跟隨 Chrome 使用 WebKit 分支的 Chromium 引擎作為自家瀏覽器核心引擎,Presto 內(nèi)核的 Opera 瀏覽器版本永遠(yuǎn)的停留在了 12.17。在 Chrome 于 2013 年推出 Blink 引擎之后,Opera 也緊跟其腳步表示將轉(zhuǎn)而使用 Blink 作為瀏覽器核心引擎。

Presto 與開源的 WebKit 和經(jīng)過谷歌加持的 Chromium 系列相比毫無推廣上的優(yōu)勢,這是 Opera 轉(zhuǎn)投 WebKit 的主要原因,并且使用 WebKit 內(nèi)核的 Opera 瀏覽器可以兼容谷歌 Chrome 瀏覽器海量的插件資源。但是換內(nèi)核的代價對于 Opera 來說過于慘痛。使用谷歌的 WebKit 內(nèi)核之后,原本快速,輕量化,穩(wěn)定的 Opera 瀏覽器變得異常的卡頓,而且表現(xiàn)不穩(wěn)定,Opera 原本舊內(nèi)核瀏覽器書簽同步到新內(nèi)核上的工作 Opera 花了整整兩年時間,期間很多 Opera 的用戶紛紛轉(zhuǎn)投谷歌瀏覽器和其他瀏覽器,造成了眾多的用戶流失。時至今日現(xiàn)在還有上千萬人在使用老版本的 Opera。

很多人都認(rèn)為 Opera 瀏覽器終止在了 12.17,此后所更新的 Opera 版本號不再是原來那個 Opera。

說好的 Presto Forever 呢?

關(guān)于移動端


移動端的瀏覽器內(nèi)核主要說的是系統(tǒng)內(nèi)置瀏覽器的內(nèi)核。

目前移動設(shè)備瀏覽器上常用的內(nèi)核有 Webkit,Blink,Trident,Gecko 等,其中 iPhone 和 iPad 等蘋果 iOS 平臺主要是 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。

總結(jié)


瀏覽器內(nèi)核主要指的是瀏覽器的渲染引擎,2013 年以前,代表有 Trident(IE),Gecko(firefox),Webkit(Safari chrome 等)以及 Presto(opera)。2013 年,谷歌開始研發(fā) blink 引擎,chrome 28 以后開始使用,而 opera 則放棄了自主研發(fā)的 Presto 引擎,投入谷歌懷抱,和谷歌一起研發(fā) blink 引擎,國內(nèi)各種 chrome系的瀏覽器(360、UC、QQ、2345 等等)也紛紛放棄 webkit,投入 blink 的懷抱。

還有一點(diǎn)文章里沒有說的很明白,就是 Webkit 其實(shí)是 KHTML 的分支,這里的 KHTML 指渲染引擎,Webkit 其實(shí)就泛指了 Webkit 的渲染引擎 WebCore,而 Webkit 引擎的 Javascript 引擎 JSCore 則是 KJS 的分支。而 chrome 則搭載了自己的 Javascript 引擎 V8。引用 各主流瀏覽器內(nèi)核介紹 里的一段話:

我們上面提到 Chrome 是基于 WebKit 的分支,而 WebKit 又由渲染引擎 “WebCore” 和 JS 解釋引擎 “JSCore” 組成,可能會讓你搞不清 V8 和 JSCore 的關(guān)系。你可以這樣理解—— WebKit 是一塊主板,JSCore 是一塊可拆卸的內(nèi)存條,谷歌實(shí)際上認(rèn)為 Webkit 中的 JSCore 不夠好,才自己搞了一個 V8 JS 引擎,這就是 Chrome 比 Safari 在某些 JS 測試中效率更高的原因。

如果說 chromium 還不足以脫離 Webkit 的 “帽子”,Blink 的出現(xiàn),代表著 chrome 將自主研發(fā)渲染引擎(Blink)以及 Javascript 引擎(V8)。可以期待在不久的將來,人們談起 chrome 想到的不是 Webkit 而是 Blink。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點(diǎn)擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多

    欧美精品久久99九九| 在线观看视频日韩精品 | 熟女高潮一区二区三区| 三级理论午夜福利在线看| 久久精品亚洲情色欧美| 日本精品中文字幕人妻| 日本国产欧美精品视频| 久草国产精品一区二区| 欧美国产极品一区二区| 一二区不卡不卡在线观看 | 亚洲品质一区二区三区| 91在线播放在线播放观看| 久久久精品区二区三区| 男人大臿蕉香蕉大视频| 久草精品视频精品视频精品| 黄片美女在线免费观看| 少妇激情在线免费观看| 黄片在线观看一区二区三区| 又黄又色又爽又免费的视频| 久久热这里只有精品视频| 少妇人妻中出中文字幕| 精品al亚洲麻豆一区| 亚洲国产黄色精品在线观看| 在线观看免费视频你懂的| 九九九热视频免费观看| 男生和女生哪个更好色| 日韩人妻有码一区二区| 日韩精品成区中文字幕| 国产成人精品在线一区二区三区| 国产又粗又长又爽又猛的视频| 午夜直播免费福利平台| 国产精品免费视频专区| 亚洲欧美日韩在线中文字幕| 精品熟女少妇一区二区三区| 精品一区二区三区不卡少妇av| 福利在线午夜绝顶三级| 免费黄色一区二区三区| 中文字幕亚洲视频一区二区| 男生和女生哪个更好色| 日本黄色高清视频久久| 色哟哟哟在线观看视频|