精品久久久久久久久久久国产字幕|国产成人一区二区三区免费看|国产精品久久久久久久久绿色|亚洲日韩精品一区二区三区无码

浙江省永康市錦尚庭門業

高性能JavaScript模板發動機原理解析

瀏覽: 作者: 來源: 時間:2024-05-21 分類:
隨著 web 發展,前端應用變得越來越復雜,基于后端的 javascript(Node.js) 也開始嶄露頭角,此時 javascript 被寄予了更大的期望,與此同時 javascript MVC 思想也開始流行起來。javascript 模板引擎作為數據...

隨著 web 發展,前端應用變得越來越復雜,基于后端的 javascript(Node.js) 也開始嶄露頭角,此時 javascript 被寄予了更大的期望,與此同時 javascript MVC 思想也開始流行起來。javascript 模板發動機作為數據與界面分離工作中最重要一環,越來越受開發者關注,近一年來在開源社區中更是百花齊放,在 Twitter、淘寶網、新浪微博、騰訊QQ空間、騰訊微博等大型網站中均能看到它們的身影。

本文將用最簡單的示例代碼描述現有的 javascript 模板發動機的原理,包括新一代 javascript 模板發動機 artTemplate 的特性實現原理,歡迎共同探討。

artTemplate 介紹

artTemplate 是新一代 javascript 模板發動機,它采用預編譯方式讓性能有了質的飛躍,并且充分利用 javascript 發動機特性,使得其性能無論在前端還是后端都有極其出色的表現。在 chrome 下渲染效率測試中分別是知名發動機 Mustache 與 micro tmpl 的 25 、 32 倍。

除了性能優勢外,調試功能也值得一提。模板調試器可以精確定位到引發渲染錯誤的模板語句,解決了編寫模板過程中無法調試的痛苦,讓開發變得高效,也避免了因為單個模板出錯導致整個應用崩潰的情況發生。

artTemplate 這一切都在 1.7kb(gzip) 中實現!

javascript 模板發動機基本原理

雖然每個發動機從模板語法、語法解析、變量賦值、字符串拼接的實現方式各有所不同,但關鍵的渲染原理仍然是動態執行 javascript 字符串。

關于動態執行 javascript 字符串,本文以一段模板代碼舉例:

這是一段非常樸素的模板寫法,其中,”” 為 closeTag (邏輯語句閉合標簽),若 openTag 后面緊跟 “=” 則會輸出變量的內容。

HTML語句與變量輸出語句被直接輸出,解析后的字符串類似:

語法分析完畢一般還會返回渲染方法:

渲染測試:

由原理實現可見,傳統 javascript 模板發動機中留下兩個待解決的問題:

1、性能:模板發動機渲染的時候依賴 Function 構造器實現,Function 與 eval、setTimeout、setInterval 一樣,提供了使用文本訪問 javascript 解析發動機的方法,但這樣執行 javascript 的性能非常低下。

2、調試:由于是動態執行字符串,若遇到錯誤調試器無法捕獲錯誤源,導致模板 BUG 調試變得異常痛苦。在沒有進行容錯的發動機中,局部模板若因為數據異常甚至可以導致整個應用崩潰,隨著模板的數目增加,維護成本將劇增。

artTemplate 高效的秘密

1、預編譯

在上述模板發動機實現原理中,因為要對模板變量進行賦值,所以每次渲染都需要動態編譯 javascript 字符串完成變量賦值。而 artTemplate 的編譯賦值過程卻是在渲染之前完成的,這種方式稱之為“預編譯”。artTemplate 模板編譯器會根據一些簡單的規則提取好所有模板變量,聲明在渲染函數頭部,這個函數類似:

這個自動生成的函數就如同一個手工編寫的 javascript 函數一樣,同等的執行次數下無論 CPU 還是內存占用都有顯著減少,性能近乎極限。

值得一提的是:artTemplate 很多特性都基于預編譯實現,如沙箱規范與自定義語法等。

2、更快的字符串相加方式

很多人誤以為數組 push 方法拼接字符串會比 += 快,要知道這僅僅是 IE6-8 的瀏覽器下。實測表明現代瀏覽器使用 += 會比數組 push 方法快,而在 v8 發動機中,使用 += 方式比數組拼接快 4.7 倍。所以 artTemplate 根據 javascript 發動機特性采用了兩種不同的字符串拼接方式。

artTemplate 調試模式原理

前端模板發動機不像后端模板發動機,它是動態解析,所以調試器無法定位到錯誤行號,而 artTemplate 通過巧妙的方式讓模板調試器可以精確定位到引發渲染錯誤的模板語句,例如:

artTemplate 支持兩種類型的錯誤捕獲,一是渲染錯誤(Render Error)與編譯錯誤(Syntax Error)。

1、渲染錯誤

渲染錯誤一般是因為模板數據錯誤或者變量錯誤產生的,渲染的時候只有遇到錯誤才會進入調試模式重新編譯模板,而不會影響正常的模板執行效率。模板編譯器根據模板換行符記錄行號,編譯后的函數類似:

當執行過程遇到錯誤,立馬拋出異常模板對應的行號,模板調試器再根據行號反查模板對應的語句并打印到控制臺。

2、編譯錯誤

編譯錯誤一般是模板語法錯誤,如不合格的套嵌、未知語法等。由于 artTemplate 沒有進行完整的詞法分析,故無法確定錯誤源所在的位置,只能對錯誤信息與源碼進行原文輸出,供開發者判斷。

開源節流

artTemplate 基于開源協議發布,無論是商業公司還是個人都可以免費在項目中使用,歡迎共同完善。

下載地址:

https://github.com/aui/artTemplate

在線預覽:

http://aui.github.com/artTemplate/

反饋:

騰訊微博 | 新浪微博

主站蜘蛛池模板: 永久黄网站免费视频性色| 久久露脸国产精品| 久久久99无码一区| 无码人妻丝袜在线视频红杏| 亚洲国产超清无码专区| 最新亚洲伦理中文字幕| 久久精品成人免费观看97| 日韩国产精品人妻无码久久久| 亚洲精品久久久久中文字幕m男| 无码伊人66久久大杳蕉网站谷歌 | 麻豆视传媒在线观看| 亚洲一区二区三区四区五区六区| 久久久久黑人强伦姧人妻| 真实的国产乱xxxx在线| 麻豆精产国品| 中文字日产幕乱五区| 与子敌伦刺激对白播放的优点 | 国产va在线观看免费| 欧美丰满大乳大屁股流白浆| 国产成人亚洲综合色就色| 人妻夜夜爽天天爽欧美色院| 免费看一区无码无a片www| 欧美人牲交a欧美精区日韩| 强奷乱码中文字幕乱老妇| 67194熟妇在线永久免费观看| 欧美最骚最疯日b视频观看| 国产末成年av在线播放| 亚洲成av人片天堂网九九| 国产福利免费视频不卡| 中文字幕人妻丝袜二区| 欧美乱大交xxxxx潮喷l头像| 亚洲一区精品无码| 西西444www无码大胆| 97无码人妻福利免费公开在线视频 | 好了av四色综合无码久久| 两性色午夜视频免费老司机| 最近中文字幕mv在线视频2018| 亚洲日韩一区二区| 精品国产人妻一区二区三区| 精品无码国产污污污免费网站| 起碰免费公开97在线视频|