1. [代码]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
strhttp://www.huiyi8.com/jiaoben/?
.replace(/[\r\t\n]/g, " ")
.split("<%").join("\t")
.replace(/((^|%>)[^\t]*)‘/g, "$1\r")
.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;
};
})();
2. [脚本代码]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>jQuery特效
<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>
相关文章
- 09-13动态 WebApi 引擎使用教程(3行代码完成动态 WebApi 构建)
- 09-13Smarty模板引擎的使用
- 09-13javascript-如果一个变量从未被使用过,它会自动从内存中释放出来吗?
- 09-13SpringBoot--- Shiro(拦截,认证)、Thymeleaf(模板引擎)
- 09-13javascript – 使用windows.location.replace刷新不使用URL中的哈希的页面
- 09-13Qt+腾讯IM开发笔记(一):腾讯IM介绍、使用和Qt集成腾讯IM-SDK的工程模板Demo
- 09-13使用Laya引擎开发微信小游戏
- 09-13使用Whoosh构建自己的搜索引擎、whoosh和jieba实现中文全文检索
- 09-13开源工作流引擎 Workflow Core 的研究和使用教程
- 09-13springboot-使用jfinal-enjoy模板