炫意html5
最早CSS3和HTML5移动技术网站之一

JavaScript模板引擎使用

[代码] tmpl.js

// Simple JavaScript Templating
// John Resig - http://ejohn.org/ - MIT Licensed
(function() {
	var cache = {};

	this.tmpl = function tmpl(str, data) {
		
		// Figure out if we're getting a template, or if we need to
		// load the template - and be sure to cache the result.
		var fn = 
			!/W/.test(str) 
			? 
			cache[str] = cache[str] || tmpl(document.getElementById(str).innerHTML) 
			:
			// Generate a reusable function that will serve as a template
			// generator (and which will be cached).
			new Function(
				"obj", "var p=[],print=function(){p.push.apply(p,arguments);};" +
	
				// Introduce the data as local variables using with(){}
				"with(obj){p.push('" +
		
				// Convert the template into pure JavaScript
				str
					.replace(/[rtn]/g, " ")
					.split("<%").join("t")
					.replace(/((^|%>)[^t]*)'/g, "$1r")
					.replace(/t=(.*?)%>/g, "',$1,'")
					.split("t")
					.join("');")
					.split("%>")
					.join("p.push('")
					.split("r")
					.join("\'") + 
				"');}return p.join('');"
			);	// Function ends

		// Provide some basic currying to the user
		return data ? fn(data) : fn;
	};
})(); 

[代码] index.html

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
	<head>
		<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
		<title>JavaScript tmpl Use Demo</title>
		<script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
		<script src="./tmpl.js" type="text/javascript"></script>
                <!-- 下面是模板user_tmpl -->
		<script type="text/html" id="user_tmpl">
			<% for ( var i = 0; i < users.length; i++ ) { %>
			<li><a href="<%=users[i].url%>"><%=users[i].name%></a></li>
			<% } %>
		</script>
		<script type="text/javascript">
                        // 用来填充模板的数据
			var users = [
				{ url: "http://baidu.com", name: "jxq"},
				{ url: "http://google.com", name: "william"},
			];
			
			$(function() {
                               // 调用模板引擎函数将数据填充到模板获得最终内容
				$("#myUl").html(tmpl("user_tmpl", users));
			});
		</script>
	</head>
	<body>
		<div>
			<ul id="myUl">
			</ul>
		</div>
	</body>
</html>

以上模板引擎是jQuery的作者写的,但是里面使用了 with() ,这个导致了其性能的下降,Tencent的UED部门糖饼曾对其进行了优化: 

/**
 * 微型模板引擎 tmpl 0.2
 *
 * 0.2 更新:
 * 1. 修复转义字符与id判断的BUG
 * 2. 放弃低效的 with 语句从而最高提升3.5倍的执行效率
 * 3. 使用随机内部变量防止与模板变量产生冲突
 *
 * @author	John Resig, Tang Bin
 * @see		http://ejohn.org/blog/javascript-micro-templating/
 * @name	tmpl
 * @param	{String}	模板内容或者装有模板内容的元素ID
 * @param	{Object}	附加的数据
 * @return	{String}	解析好的模板
 *
 * @example
 * 方式一:在页面嵌入模板
 * 
 * tmpl('tmpl-demo', {name: 'demo data', list: [202, 96, 133, 134]})
 * 
 * 方式二:直接传入模板:
 * var demoTmpl =
 * '
 
 <ol>
	'
 * + '<% for (var i = 0, l = list.length; i < length; i ++) { %>'
 * +	'
  
  <li><%=list[i]%></li>
'
 * + '<% } %>'
 * +'
 
 </ol>
';

 * var render = tmpl(demoTmpl);
 * render({name: 'demo data', list: [202, 96, 133, 134]});
 * 
 * 这两种方式区别在于第一个会自动缓存编译好的模板,
 * 而第二种缓存交给外部对象控制,如例二中的 render 变量。
 */

var tmpl = (function (cache, $) {
return function (str, data) {
	var fn = !/s/.test(str)
	? cache[str] = cache[str]
		|| tmpl(document.getElementById(str).innerHTML)
		
	: function (data) {
		var i, variable = [$], value = [[]];
		for (i in data) {
			variable.push(i);
			value.push(data[i]);
		};
		return (new Function(variable, fn.$))
		.apply(data, value).join("");
	};
	
	fn.$ = fn.$ || $ + ".push('" 
	+ str.replace(//g, "\")
		 .replace(/[rtn]/g, " ")
		 .split("<%").join("t")
		 .replace(/((^|%>)[^t]*)'/g, "$1r")
		 .replace(/t=(.*?)%>/g, "',$1,'")
		 .split("t").join("');")
		 .split("%>").join($ + ".push('")
		 .split("r").join("'")
	+ "');return " + $;

	return data ? fn(data) : fn;
}})({}, '$' + (+ new Date));

炫意HTML5 » JavaScript模板引擎使用

CSS3教程HTML5教程