本來想把之前對artTemplate源碼解析的注釋放上來分享下,不過隔了一年,找不到了,只好把當時分析模板引擎原理后,自己嘗試
寫下的模板引擎與大家分享下,留個紀念,記得當時還對比了好幾個模板引擎來著。
這里所說的js的模板引擎,用的是原生的javascript語法,所以很類似php的原生模板引擎。
前端模板引擎的作用?
1. 可以讓前端開發更簡單,不需要為了生成一個dom結構而使用+運算符去拼接字符串,而只需要一個元素的(里面的html模板),或者一個變量(存儲著模板),或者 一個模板文件
2. 易于維護,減少耦合,假使你的dom結構變化了,不需要更改邏輯代碼,而只需要更改對應的模板(文件)
3. 可以緩存,如果你的模板是一個類似.tpl的文件,那么完全可以用瀏覽器去加載,并且還存下來。說到.tpl文件,可以做的不僅僅是緩存了,你還可以做到通過模塊加載器
將.tpl作為一個模塊,那就可以按需加載文件,不是更省寬帶,加快頁面速度嗎?
4. 等等等
前端模板引擎的原理?
原理很簡單就是 對象(數據)+ 模板(含有變量) -> 字符串(html)
前端模板引擎的如何實現?
通過解析模板,根據詞法,將模板轉換成一個函數,然后通過調用該函數,并傳遞對象(數據),輸出字符串(html)
(當然,具體的還要看代碼的)
就像這樣:
例子:
<!DOCTYPE HTML>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>ice demo</title>
<script src="/javascripts/jquery/jquery-1.7.2.js"></script>
<script src="/javascripts/ice/ice.js"></script>
<body>
<div id="content"></div>
</body>
<script type="text/html" id="tpl">
<div>here is the render result:</div>
<% = this.title() ;%>
<table border=1>
<% for(var i=0,tl = this.trs.length,tr;i<tl;i++){ %>
<%
tr = this.trs[i];
if (tr.sex === "女") {
%>
<tr>
<td><%= tr.name;; %></td> <td><%= tr.age; %></td> <td><%= tr.sex || "男" %></td>
</tr>
<% } %>
<% } %>
</table>
<img src="<%= this.href %>">
<%= this.include('tpl2',this); %>
</script>
<script type="text/html" id="tpl2">
<div>here is the render result:</div>
<% = this.print('Welcome to Ice Template') ;%>
<table border=1>
<% for(var i=0,tl = this.trs.length,tr;i<tl;i++){ %>
<%
tr = this.trs[i];
if (tr.sex === "男") {
%>
<tr>
<td><%= tr.name;; %></td> <td><%= tr.age; %></td> <td><%= tr.sex || "男" %></td>
</tr>
<% } %>
<% } %>
</table>
<img src="<%= this.href %>">
</script>
<script>
var trs = [
{name:"隱形殺手",age:29,sex:"男"},
{name:"索拉",age:22,sex:"男"},
{name:"fesyo",age:23,sex:"女"},
{name:"戀妖壺",age:18,sex:"男"},
{name:"亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb