ejs v9 javascript模板系統(tǒng)
更新時(shí)間:2012年03月21日 17:04:42 作者:
我的模板系統(tǒng)升一下級(jí), 繼續(xù)在新公司里面用。 現(xiàn)在幾在互聯(lián)網(wǎng)公司沒(méi)有不用javascript模板了, 什么TX, 百度, 新浪, 360什么的, 最后瀑布流的流行, 里面又有許多用到模板
本版本就是改回v6的形態(tài),后端數(shù)據(jù)還是帶@前端才方便查看與調(diào)試。昨天也與一TX前端工程師討論過(guò)這個(gè)必要性。取得模板中的需要填寫的變量,再與后端傳過(guò)來(lái)的JSON進(jìn)行比較,盡早進(jìn)行數(shù)據(jù)驗(yàn)證。這種技術(shù),可以看一看PHP的變量命名就知了,帶是帶$前綴。
在之前的版本中,如果輸出語(yǔ)句帶分號(hào)或逗號(hào)是會(huì)報(bào)錯(cuò)的
<script type="tmpl" id="table_tmpl">
<table>
<& for(var i=0,tl = @trs.length,tr;i<tl;i++){ &>
<& tr = @trs[i]; &>
<tr>
<td><&= tr.name; &></td> <td><&= tr.age; &></td> <td><&= tr.sex || "男" &></td>
</tr>
<& } &>
</table>
<&# 怎么可能不支持圖片 &>
<img src="<&= @href &>">
</script>
因?yàn)閮?nèi)部生成的字符串是這個(gè)樣子的:
__views(data.tr.name;)
為了防止用戶順手把個(gè)逗號(hào)或分號(hào)上去,本版本自動(dòng)幫你處理了.
rlastSemi = /[,;]\s*$/
// 略
case "="://處理后臺(tái)返回的變量(輸出到頁(yè)面的);
logic = els[0].substring(1);
if(logic.indexOf("@")!==-1){
temp.push( startOfHTML, logic.replace(rAt,"$1data.").replace(rlastSemi,''), endOfHTML );
}else{
temp.push( startOfHTML, logic.replace(rlastSemi,''), endOfHTML );
}
break;
例子
下面是一個(gè)模板,放置于瀏覽器會(huì)忽略解析JS代碼的script標(biāo)簽之內(nèi), 注意trs與href前面都帶有@標(biāo)識(shí)符。
<script type="tmpl" id="table_tmpl">
<table>
<& for(var i=0,tl = @trs.length,tr;i<tl;i++){ &>
<& tr = @trs[i]; &>
<tr>
<td><&= tr.name &></td> <td><&= tr.age &></td> <td><&= tr.sex || "男" &></td>
<&# 導(dǎo)入子模板 &>
<&= $.ejs("tds_tmpl"); &>
</tr>
<& } &>
</table>
<&# 怎么可能不支持圖片 &>
<img src="<&= @href &>">
</script>
<!-- 這是子模板 -->
<script type="tmpl" id="tds_tmpl">
<td>靜態(tài)的表格</d> <td>靜態(tài)的表格</d> <td>靜態(tài)的表格</d>
</script>
這是它的JS代碼:
$.require("ready,more/ejs,node", function(){
var trs = [
{name:"隱形殺手",age:29,sex:"男"},
{name:"索拉",age:22,sex:"男"},
{name:"fesyo",age:23,sex:"女"},
{name:"戀妖壺",age:18,sex:"男"},
{name:"竜崎",age:25,sex:"男"},
{name:"你不懂的",age:30,sex:"女"}
]
var html = $.ejs("table_tmpl",{
trs: trs,
href: "http://www.dhdzp.com//rubylouvre/202906/o_type4.jpg"
});
$("#table_tc").html(html)
});

ejs源代碼
$.define("ejs", "lang",function(){
var
_startOfHTML = "\t__views.push(",
_endOfHTML = ");\n",
sRight = "&>",
rLeft = /\s*<&\s*/,
rRight = /\s*&>\s*/,
rAt = /(^|[^\w\u00c0-\uFFFF_])(@)(?=\w)/g,
rLastSemi = /[,;]\s*$/
var ejs2 = $.ejs = function(id,data){
data = data || {};
if( !ejs2[id] ){
var rleft = rLeft,
rright = rRight,
sright = sRight,
rlastSemi = rLastSemi,
startOfHTML = _startOfHTML,
endOfHTML = _endOfHTML, str , logic,
el = document.getElementById(id);
if (!el) throw "can not find the target element";
str = el.innerHTML;
var arr = str.trim().split(rleft),
buff = ["var __views = [];\n"],temp = [],i = 0,n = arr.length,els,segment;
while(i < n){//逐行分析,以防歧義
segment = arr[i++];
els = segment.split(rright);
if( ~segment.indexOf(sright) ){//這里不使用els.length === 2是為了避開IE的split bug
switch ( els[0].charAt(0) ) {
case "="://處理后臺(tái)返回的變量(輸出到頁(yè)面的);
logic = els[0].substring(1);
if(logic.indexOf("@")!==-1){
temp.push( startOfHTML, logic.replace(rAt,"$1data.").replace(rlastSemi,''), endOfHTML );
}else{
temp.push( startOfHTML, logic.replace(rlastSemi,''), endOfHTML );
}
break;
case "#"://處理注釋
break;
default://處理邏輯
logic = els[0];
if(logic.indexOf("@")!==-1){
temp.push( logic.replace(rAt,"$1data."), "\n" );
}else{
temp.push( logic, "\n" );
}
}
//處理靜態(tài)HTML片斷
els[1] && temp.push(startOfHTML, $.quote( els[1] ), endOfHTML)
}else{
//處理靜態(tài)HTML片斷
temp.push(startOfHTML, $.quote( els[0] ), endOfHTML );
}
}
ejs2[id] = new Function("data",buff.concat(temp).join("")+';return __views.join("");');
return ejs2[id]( data )
}
return ejs2[id]( data )
}
})
// ejs v9!
在之前的版本中,如果輸出語(yǔ)句帶分號(hào)或逗號(hào)是會(huì)報(bào)錯(cuò)的
復(fù)制代碼 代碼如下:
<script type="tmpl" id="table_tmpl">
<table>
<& for(var i=0,tl = @trs.length,tr;i<tl;i++){ &>
<& tr = @trs[i]; &>
<tr>
<td><&= tr.name; &></td> <td><&= tr.age; &></td> <td><&= tr.sex || "男" &></td>
</tr>
<& } &>
</table>
<&# 怎么可能不支持圖片 &>
<img src="<&= @href &>">
</script>
因?yàn)閮?nèi)部生成的字符串是這個(gè)樣子的:
__views(data.tr.name;)
為了防止用戶順手把個(gè)逗號(hào)或分號(hào)上去,本版本自動(dòng)幫你處理了.
復(fù)制代碼 代碼如下:
rlastSemi = /[,;]\s*$/
// 略
case "="://處理后臺(tái)返回的變量(輸出到頁(yè)面的);
logic = els[0].substring(1);
if(logic.indexOf("@")!==-1){
temp.push( startOfHTML, logic.replace(rAt,"$1data.").replace(rlastSemi,''), endOfHTML );
}else{
temp.push( startOfHTML, logic.replace(rlastSemi,''), endOfHTML );
}
break;
例子
下面是一個(gè)模板,放置于瀏覽器會(huì)忽略解析JS代碼的script標(biāo)簽之內(nèi), 注意trs與href前面都帶有@標(biāo)識(shí)符。
復(fù)制代碼 代碼如下:
<script type="tmpl" id="table_tmpl">
<table>
<& for(var i=0,tl = @trs.length,tr;i<tl;i++){ &>
<& tr = @trs[i]; &>
<tr>
<td><&= tr.name &></td> <td><&= tr.age &></td> <td><&= tr.sex || "男" &></td>
<&# 導(dǎo)入子模板 &>
<&= $.ejs("tds_tmpl"); &>
</tr>
<& } &>
</table>
<&# 怎么可能不支持圖片 &>
<img src="<&= @href &>">
</script>
<!-- 這是子模板 -->
<script type="tmpl" id="tds_tmpl">
<td>靜態(tài)的表格</d> <td>靜態(tài)的表格</d> <td>靜態(tài)的表格</d>
</script>
這是它的JS代碼:
復(fù)制代碼 代碼如下:
$.require("ready,more/ejs,node", function(){
var trs = [
{name:"隱形殺手",age:29,sex:"男"},
{name:"索拉",age:22,sex:"男"},
{name:"fesyo",age:23,sex:"女"},
{name:"戀妖壺",age:18,sex:"男"},
{name:"竜崎",age:25,sex:"男"},
{name:"你不懂的",age:30,sex:"女"}
]
var html = $.ejs("table_tmpl",{
trs: trs,
href: "http://www.dhdzp.com//rubylouvre/202906/o_type4.jpg"
});
$("#table_tc").html(html)
});

ejs源代碼
復(fù)制代碼 代碼如下:
$.define("ejs", "lang",function(){
var
_startOfHTML = "\t__views.push(",
_endOfHTML = ");\n",
sRight = "&>",
rLeft = /\s*<&\s*/,
rRight = /\s*&>\s*/,
rAt = /(^|[^\w\u00c0-\uFFFF_])(@)(?=\w)/g,
rLastSemi = /[,;]\s*$/
var ejs2 = $.ejs = function(id,data){
data = data || {};
if( !ejs2[id] ){
var rleft = rLeft,
rright = rRight,
sright = sRight,
rlastSemi = rLastSemi,
startOfHTML = _startOfHTML,
endOfHTML = _endOfHTML, str , logic,
el = document.getElementById(id);
if (!el) throw "can not find the target element";
str = el.innerHTML;
var arr = str.trim().split(rleft),
buff = ["var __views = [];\n"],temp = [],i = 0,n = arr.length,els,segment;
while(i < n){//逐行分析,以防歧義
segment = arr[i++];
els = segment.split(rright);
if( ~segment.indexOf(sright) ){//這里不使用els.length === 2是為了避開IE的split bug
switch ( els[0].charAt(0) ) {
case "="://處理后臺(tái)返回的變量(輸出到頁(yè)面的);
logic = els[0].substring(1);
if(logic.indexOf("@")!==-1){
temp.push( startOfHTML, logic.replace(rAt,"$1data.").replace(rlastSemi,''), endOfHTML );
}else{
temp.push( startOfHTML, logic.replace(rlastSemi,''), endOfHTML );
}
break;
case "#"://處理注釋
break;
default://處理邏輯
logic = els[0];
if(logic.indexOf("@")!==-1){
temp.push( logic.replace(rAt,"$1data."), "\n" );
}else{
temp.push( logic, "\n" );
}
}
//處理靜態(tài)HTML片斷
els[1] && temp.push(startOfHTML, $.quote( els[1] ), endOfHTML)
}else{
//處理靜態(tài)HTML片斷
temp.push(startOfHTML, $.quote( els[0] ), endOfHTML );
}
}
ejs2[id] = new Function("data",buff.concat(temp).join("")+';return __views.join("");');
return ejs2[id]( data )
}
return ejs2[id]( data )
}
})
// ejs v9!
相關(guān)文章
canvas實(shí)現(xiàn)弧形可拖動(dòng)進(jìn)度條效果
本篇文章主要介紹了canvas實(shí)現(xiàn)弧形可拖動(dòng)進(jìn)度條的實(shí)例方法,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-05-05
簡(jiǎn)單時(shí)間提示DEMO從0開始一直進(jìn)行計(jì)時(shí)
點(diǎn)擊按鈕輸入框會(huì)從0開始一直進(jìn)行計(jì)時(shí),具體的實(shí)現(xiàn)示例如下,感興趣的朋友可以嘗試操作下哦2013-11-11
JavaScript判斷是否為數(shù)字的幾種方式匯總(推薦!)
有時(shí)候需要根據(jù)輸入的內(nèi)容來(lái)進(jìn)行計(jì)算,這個(gè)時(shí)候就需要判斷輸入的內(nèi)容是否是數(shù)字,下面這篇文章主要給大家介紹了關(guān)于JavaScript判斷是否為數(shù)字的幾種方式,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
JavaScript將DOM事件處理程序封裝為event.js 出現(xiàn)的低級(jí)錯(cuò)誤問(wèn)題
這篇文章主要介紹了JavaScript將DOM事件處理程序封裝為event.js 出現(xiàn)的低級(jí)錯(cuò)誤問(wèn)題做個(gè)筆錄,以防出現(xiàn)類似錯(cuò)誤,需要的朋友可以參考下2016-08-08
js判斷數(shù)據(jù)類型如判斷是否為數(shù)組是否為字符串等等
js判斷數(shù)據(jù)類型如判斷是否為數(shù)組類型、判斷是否為字符串類型、判斷是否為數(shù)值類型等等,本文有幾個(gè)不錯(cuò)的示例,大家可以學(xué)習(xí)下2014-01-01

