DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> jQuery入門知識 >> JQuery特效代碼 >> JSON JQUERY模板實現說明
JSON JQUERY模板實現說明
編輯:JQuery特效代碼     
可是在客戶端再現數據也是一個不小的問題,用javascript處理經常會遇到很繁瑣的事.尤其大批量具有相同結構的數據,例如表格,處理方式不盡如意.如果能有一個模板控件,就像服務器端asp.net Gridview或者repeater一樣的東西就好很多.最近看到一個非常優秀的解決方案,讓我在使用方便的同時不得不為作者的精巧設計而作一番感歎.該解決方案用了區區二十幾行代碼,實現了別人要用幾十甚至上百K的js庫所做的工作.它就是John Resig 的 Microtemplating engine.大師Rick Strahl有一篇文章專門對此作了詳細講述(Client Templating with Jquery).我在這裡把最核心部分提取出來以方便國人學習。

下面一段程序就是microtemplating engine.

代碼如下:
var _tmplCache = {}
this.parseTemplate = function(str, data) {
/// <summary>
/// Client side template parser that uses <#= #> and <# code #> expressions.
/// and # # code blocks for template expansion.
/// NOTE: chokes on single quotes in the document in some situations
/// use ’ for literals in text and avoid any single quote
/// attribute delimiters.
/// </summary>
/// <param name="str" type="string">The text of the template to expand</param>
/// <param name="data" type="var">
/// Any data that is to be merged. Pass an object and
/// that object's properties are visible as variables.
/// </param>
/// <returns type="string" />
var err = "";
try {
var func = _tmplCache[str];
if (!func) {
var strFunc =
"var p=[],print=function(){p.push.apply(p,arguments);};" +
"with(obj){p.push('" +

str.replace(/[\r\t\n]/g, " ")
.replace(/'(?=[^#]*#>)/g, "\t")
.split("'").join("\\'")
.split("\t").join("'")
.replace(/<#=(.+?)#>/g, "',$1,'")
.split("<#").join("');")
.split("#>").join("p.push('")
+ "');}return p.join('');";

//alert(strFunc);
func = new Function("obj", strFunc);
_tmplCache[str] = func;
}
return func(data);
} catch (e) { err = e.message; }
return "< # ERROR: " + err.htmlEncode() + " # >";
}

如何使用:
代碼如下:parseTemplate($("#ItemTemplate").html(),{ name: "rick", address: { street: "32 kaiea", city: "paia"} } );

上面程序所用的模板:
代碼如下:<script id="ItemTemplate" type="text/html"><div><div><#= name #></div><div><#= address.street #></div> </div></script>

如果想用循環:
代碼如下:$.each(dataarray,function(index,dataItem){
parseTemplate($("#ItemTemplate").html(), dataItem );
})
很簡單很精巧吧?
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved