jQuery.loadTemplate客户端模板
jQuery.Template虽然用起来没有Mustache简洁和方便,还是学习了解一下,做个笔记。
模板可以定义在页面script标签,如下
- <script type="text/html" id="template">
- <div data-content="author"></div>
- <div data-content="date"></div>
- <img data-src="authorPicture" data-alt="author"/>
- <div data-content="post"></div>
- </script>
也可以定义到独立的html文件中,好处是可以使用浏览器缓存,例如:
- <div style="margin:50;border:solid 1px red">
- <div data-content-text="author"></div>
- <div data-content="date"></div>
- <img data-src="authorPicture" data-alt="author" />
- <div data-content="post"></div>
- </div>
- <hr />
在客户端调用,如果数组数据,模板自动循环重复输出
- //$("#template-container").loadTemplate($("#template"),
- // {
- // author: 'Joe Bloggs',
- // date: '25th May 2013',
- // authorPicture: 'https://www.baidu.com/img/bd_logo1.png',
- // post: 'This is the contents of my post'
- // });
- $("#template-container").loadTemplate("Templates/template.html",
- [{
- author: 'Joe Bloggs',
- date: '25th May 2013',
- authorPicture: 'https://www.baidu.com/img/bd_logo1.png',
- post: 'This is the contents of my post'
- },
- {
- author: 'Wilson就是看到看看',
- date: '25th May 2013',
- authorPicture: 'https://www.baidu.com/img/bd_logo1.png',
- post: 'This is the contents of my post'
- }
- ]);
使用jquery.template 输出table
html:
- <table border="1">
- <thead>
- <tr>
- <th>Id</th>
- <th>Name</th>
- </tr>
- </thead>
- <tbody id="tbody">
- </tbody>
- </table>
template:
- <tr>
- <td data-content="id"></td>
- <td data-content="name"></td>
- </tr>
javascript:
- var data = [];
- for (var i = 0; i < 10; i++) {
- data.push({ "id": i, "name": "user_name_" + i.toString() });
- }
- $("#tbody").loadTemplate("Templates/tbList.html", data);
参考:https://github.com/codepb/jquery-template
数据绑定属性
- There are a number of different bindings and ways to bind the data. The following attributes are available:
- "data-innerHTML" (>= 1.4.5) - binds the value supplied to the content (innerHTML) of the element (uses $(elem).html(value))
- "data-content" - alias for the newer "data-innerHTML"
- "data-content-text" - binds the value supplied to the content of the element as text (uses $(elem).text(value))
- "data-content-append" - appends the value to the end of the element (uses $(elem).append(value))
- "data-content-prepend" - prepends the value to the beginning of the element (uses $(elem).prepend(value))
- "data-id" - sets the id of the element to the value provided (uses $(elem).attr("id", value));
- "data-href" - sets the href value of the element to the value provided (uses $(elem).attr("href", value));
- "data-alt" - sets the alt value of the element to the value provided (uses $(elem).attr("alt", value));
- "data-value" - sets the value attribute of the element to the value provided (uses $(elem).val(value))
- "data-class" - sets the class attribute of the element to the value provided (uses $(elem).class(value))
- "data-link" - sets the innerHtml of the element to be a link to the value provided (wraps the content in an <a> tag).
- "data-link-wrap" - wraps the element in a link to the value provided. Same as "data-link", but the <a> tag wraps the element as well as the content.
- "data-options" - adds options to a select box. The value for this should reference an array of strings, each option will be output as a separate option. The value will be the same as the displayed text for each option. For a more powerful version of this look at the data-template-bind option.
自定义格式化方法
- $.addTemplateFormatter({
- UpperCaseFormatter : function(value, template) {
- return value.toUpperCase();
- },
- LowerCaseFormatter : function(value, template) {
- return value.toLowerCase();
- },
- SameCaseFormatter : function(value, template) {
- if(template == "upper") {
- return value.toUpperCase();
- } else {
- return value.toLowerCase();
- }
- }
- });
模板
- <tr>
- <td data-content="id"></td>
- <td data-content="name" data-format="LowerCaseFormatter"></td>
- </tr>
jQuery.loadTemplate客户端模板的更多相关文章
- MVC下的客户端模板技术
1.引言 在Web编程中,我们有时经常需要使用Ajax来访问服务端的接口,然后使用这些返回的数据(一般格式都是JSON)来展示客户端的相关信息.例如:在一个商品列表,我们点击某一样的商品,查看该商品的 ...
- javascript&&jquery编写插件模板
javascrpt插件编写模板 这里不分享如何编写插件,只留一个框架模板,使用面向对象的形式进行编写,方便管理 ;(function(window,document){ function FnName ...
- jquery jtemplates.js模板渲染引擎的详细用法第三篇
jquery jtemplates.js模板渲染引擎的详细用法第三篇 <span style="font-family:Microsoft YaHei;font-size:14px;& ...
- jquery jtemplates.js模板渲染引擎的详细用法第二篇
jquery jtemplates.js模板渲染引擎的详细用法第二篇 关于jtemplates.js的用法在第一篇中已经讲过了,这里就直接上代码,不同之处是绑定模板的方式,这里讲模板的数据专门写一个t ...
- jquery jtemplates.js模板渲染引擎的详细用法第一篇
jquery jtemplates.js模板渲染引擎的详细用法第一篇 Author:ching Date:2016-06-29 jTemplates是一个基于JQuery的模板引擎插件,功能强大,有了 ...
- jquery.tmpl.js 模板引擎用法
1.0 引入: <script src="/js/jquery.tmpl.min.js"></script> 2.0 模板: <script type ...
- AMQ学习笔记 - 05. 客户端模板化
概述 客户端编程模型中,大部分的步骤都是相同的.将相同的部分做成模板,将不同的部分预留接口,实现者就只需要针对不同的部分提供实现. 设计 类图 发送方客户端 说明: 基于模板的思想,SendTempl ...
- jquery判断客户端的类型
针对不同客户端下载链接的页面响应样式不一样,更人性点而已 //匹配客户端类型 var isAndroid = navigator.userAgent.toLowerCase().match(/andr ...
- jquery的一个模板引擎-zt
jQuery-jTemplate.js下载:http://jtemplates.tpython.com/ 一 , 简单介绍 它是一个基于jQuery开发的javascript模板引擎.它主要的作用如下 ...
随机推荐
- bing统计【转自CSDN博客】
文章来源:http://blog.csdn.net/aa512690069/article/details/17918799 其原文是微软一个小题目:http://hero.csdn.net/Ques ...
- linux -samba
yum install samba samba-client samba-swat samba-common-3.6.9-151.el6.x86_64 //主要提供samba服务器的设置文件与设置文件 ...
- mvn 命令
mvn eclipse:eclipse 用mvn把文件转化成eclipse支持的文件 mvn install 打包jar,放到本地仓库 ,在打包的时候还会执行单元测试,不需要的话运行(不需要打入 ...
- paypal接口对接注意事项
追加:新的设定画面 在paypal对接过程中,会存在return_url和notify两种 分别用pdt和ipn实现 但是对于paypal,大家请注意,真实环境和沙盒测试环境的区别 你可以到www.p ...
- TP框架基础
什么是TP框架: 一堆代码的集合,里边有变量.函数.类.常量,设计模式MVC.AR数据库.单例等等.全称是Tinkphp框架; 为什么使用框架: 使用框架将全部精力集中在业务层次,节省50-60%的工 ...
- MongoDB shell 格式化
直接的方法: db.collection.find().pretty(); 如果想要所有的查询都格式化,可以执行: echo "DBQuery.prototype._prettyShell ...
- Jquery实现购物车物品数量的加减特效
今天网友翠儿在用Jquery实现购物车物品数量的加减特效的时候遇到问题来问我,我后来帮她解决了这个Jquery特效,现在把它整理出来分享给大家用,虽然功能比较简单,但是很实用. 主要包括了以下功能: ...
- 【freemaker】之循环,判断,对象取值
entity: public class Employee { private Integer id; private String name; private Integer age; privat ...
- c++封装编写线程池
在csapp学习或者其他linux底层编程的过程中,一般都会举一些多线程或多进程的例子,配合底层同步原语.系统调用api来解释怎么创建多线程/多进程. 但是这些例子和实际项目中所用到的多线程/多进程编 ...
- 使用Spring的命名空间p装配属性-摘自《Spring实战(第3版)》
使用<property>元素为Bean的属性装配值和引用并不太复杂.尽管如此,Spring的命名空间p提供了另一种Bean属性的装配方式,该方式不需要配置如此多的尖括号. 命名空间p的sc ...