使用jQuery模板来展现json数据的代码


Posted in Javascript onOctober 22, 2010

完整代码:

$.fn.parseTemplate = function(data) 
{ 
var str = (this).html(); 
var _tmplCache = {} 
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.toString() + " # >"; 
}

使用方法:

首先声明这个模板

<script id="template" type="text/html"> 
<table style="width:400px;"> 
<thead> 
<tr> 
<th>name</th> 
<th>age</th> 
<th>date</th> 
<th>type</th> 
</tr> 
</thead> 
<tbody> 
<# var xing = items.pm; 
#> 
<tr> 
<td> 
<#= xing.key #> 
</td> 
<td> 
<#= xing.key1 #> 
</td> 
<td> 
<#= xing.key #> 
</td> 
<td> 
<#= items.pm1 #> 
</td> 
</tr> 
<# 
#> 
</tbody> 
</table> 
<br /> 
<#= items.pm.length #> 记录 
</script>

然后使用
$(function(){ 
var json={"items":{"pm":{"key":"value","key1":"value1"},"pm1":"pmvalue"}}; 
var output=$('#template').parseTemplate(json); 
$('#cc').html(output); 
})

就是这么简单!
Javascript 相关文章推荐
IE6下通过a标签点击切换图片的问题
Nov 14 Javascript
setTimeout函数兼容各主流浏览器运行执行效果实例
Jun 13 Javascript
jquery实现TAB选项卡鼠标经过带延迟效果的方法
Jul 27 Javascript
Javascript中级语法快速入手
Jul 30 Javascript
node.js路径处理方法以及绝对路径详解
Mar 04 Javascript
JS验证不重复验证码
Feb 10 Javascript
基于jQuery使用Ajax动态执行模糊查询功能
Jul 05 jQuery
vue自定义移动端touch事件之点击、滑动、长按事件
Jul 10 Javascript
js中数组对象去重的两种方法
Jan 18 Javascript
Node.js Event Loop各阶段讲解
Mar 08 Javascript
vue中v-for循环选中点击的元素并对该元素添加样式操作
Jul 17 Javascript
微信小程序实现可长按移动控件
Nov 01 Javascript
jQuery 表单验证扩展(四)
Oct 20 #Javascript
jQuery 表单验证扩展(三)
Oct 20 #Javascript
jQuery 表单验证扩展代码(二)
Oct 20 #Javascript
事件模型在各浏览器中存在差异
Oct 20 #Javascript
自写简单JS判断是否已经弹出页面
Oct 20 #Javascript
javascript attachEvent绑定多个事件执行顺序问题
Oct 20 #Javascript
兼容IE与firefox火狐的回车事件(js与jquery)
Oct 20 #Javascript
You might like
让php处理图片变得简单 基于gb库的图片处理类附实例代码下载
2011/05/17 PHP
网页上facebook分享功能具体实现
2014/01/26 PHP
PHP统计nginx访问日志中的搜索引擎抓取404链接页面路径
2014/06/30 PHP
ThinkPHP使用smarty模板引擎的方法
2014/07/01 PHP
PHP微信开发之微信消息自动回复下所遇到的坑
2016/05/09 PHP
php使用PDO从数据库表中读取数据的实现方法(必看)
2017/06/02 PHP
详解强大的jQuery选择器之基本选择器、层次选择器
2012/02/07 Javascript
JS 在指定数组中随机取出N个不重复的数据
2014/06/10 Javascript
JavaScript数组常用方法
2015/03/02 Javascript
在JavaScript中使用对数Math.log()方法的教程
2015/06/15 Javascript
js编写一个简单的产品放大效果代码
2016/06/27 Javascript
vue使用watch 观察路由变化,重新获取内容
2017/03/08 Javascript
angular-ngSanitize模块-$sanitize服务详解
2017/06/13 Javascript
JS获取子、父、兄节点方法小结
2017/08/14 Javascript
Angular4绑定html内容出现警告的处理方法
2017/11/03 Javascript
JavaScript实现百度搜索框效果
2020/03/26 Javascript
JavaScript 实现HTML DOM增删改查操作的常见方法详解
2020/01/04 Javascript
详解JS函数防抖
2020/06/05 Javascript
解决vue单页面 回退页面 keeplive 缓存问题
2020/07/22 Javascript
详解vue组件之间的通信
2020/08/30 Javascript
Django imgareaselect手动剪切头像实现方法
2015/05/26 Python
Python装饰器实现几类验证功能做法实例
2017/05/18 Python
python 系统调用的实例详解
2017/07/11 Python
python实现超市扫码仪计费
2018/05/30 Python
Linux CentOS Python开发环境搭建教程
2018/11/28 Python
python对绑定事件的鼠标、按键的判断实例
2019/07/17 Python
Python pandas用法最全整理
2019/08/04 Python
突袭HTML5之Javascript API扩展1—Web Worker异步执行及相关概述
2013/01/31 HTML / CSS
瑞典廉价机票预订网站:Seat24
2018/06/19 全球购物
酒店个人求职信范文
2014/01/25 职场文书
高校十八大报告感想
2014/01/27 职场文书
八一建军节活动方案
2014/02/10 职场文书
农林经济管理专业自荐信
2014/09/01 职场文书
复活读书笔记
2015/06/29 职场文书
七年级作文之游记
2019/12/11 职场文书
PyTorch dropout设置训练和测试模式的实现
2021/05/27 Python