otmpl 是一个轻量级前端模版(仅有39行无压缩代码,支持缓存),所用指令仅需[#...#]和{#...#},前者包含需要输出html语句,后者包含js变量。 支持javascript完整语法,你可以写for或者while或者其他任一javascript的语法。这个模板参考了YaYaTemplate,但我对其进行优化和改良,并缩短整体代码,提供更好的支持。

jQuery.tmpl = function (str, data, helper)
  • str:一个 jQuery 对象或字符串
  • data:json对象。
  • helper:扩展对象,例如下面示例中自定义一个方法。
  • 注意:str的内部采用 this.XXX 来访问 data,如:this.id == data.id。
缓存:
缓存只针对 jQuery.tmpl 方法,并且 str 参数必须是一个 jQuery 对象,利用 $.data 对渲染函数进行存储缓存。如以下代码执行两次“jQuery.tmpl($('#demo'),{id:1})”,只会分析一次,若传入的是“jQuery.tmpl($('#demo').html(),{id:1})”则会分析两次。
 
Template:
 
Scripts:
 
Result1:
 
Result2:
示例+源码:
 
复杂示例:
<script id="addtmp" type="text/html">
var item = {};
var value = {};
if(this.id)
{
item.title = " 编辑 [ " + this.id + " ]";
item.icon = "icon-create";
item.url = "@Url.Action("AddData")";
item.success = function(data){
$.msg.alert('新建成功!新的编号为:' + data.value + '。');
$('#dataGrid').datagrid('reload');
$('#dlg').dialog('close');
};
var data = $.api('@Url.Action("GetDataByID")' + '/' + this.id)
if(data){
if(data.value != null) value = data.value;
else{
$.msg.error('错误 '+data.code,data.message);
$('#dlg').dialog('close');
}
}
else{
$.msg.error('数据访问发生了错误!');
$('#dlg').dialog('close');
}
}
else
{
item.title = " 新建";
item.icon = "icon-modify";
item.url = "@Url.Action("ModifyData")";
item.success = function(data){
$.msg.alert(data ? '保存成功!' : '保存失败,数据可能不存在!');
$('#dataGrid').datagrid('reload');
$('#dlg').dialog('close');
};
}
[#
<div id="dlg" class="easyui-dialog" title="{#item.title#}" style="width: 400px; height: 210px; padding: 10px"
data-options="
iconCls: '{#item.icon#}',
modal:true
">
<div class="filterArea onepcssgrid">
<form class="api-form" data-options="
url:'{#item.url#}',
success:{#item.success#}">
<div>
<div class="onerow">
<div class="col2 text-right">Address</div>
<div class="col9">
<input type="hidden" name="id" value="{#value.id#}" />
<input type="text" name="address" style="width: 100%" value="{#value.address#}" />
</div>
</div>
<div class="onerow">
<div class="col2 text-right">City</div>
<div class="col9">
<input type="text" name="city" style="width: 100%" value="{#value.city#}" />
</div>
</div>
<div class="onerow">
<div class="col2 text-right">Start</div>
<div class="col9">
<input type="text" name="start" style="width: 100%" value="{#value.start#}" />
</div>
</div>
<div class="onerow">
<div class="col2 text-right">End</div>
<div class="col9">
<input type="text" name="end" style="width: 100%" value="{#value.end#}" />
</div>
</div>
</div>
<div style="padding: 5px; width: 100%; margin-top: 5px; text-align: center; height: 22px;">
<input class="btn orange" type="submit" value="{#item.title#}" />
<input class="btn white" type="reset" value="清空" />
</div>
</form>
</div>
</div>
#]
</script>

39行代码实现JS HTML模板(轻量+高效+易用)的更多相关文章

  1. 一个只有99行代码的JS流程框架(二)

    欢迎大家关注腾讯云技术社区-博客园官方主页,我们将持续在博客园为大家推荐技术精品文章哦~ 张镇圳,腾讯Web前端高级工程师,对内部系统前端建设有多年经验,喜欢钻研捣鼓各种前端组件和框架. 导语 前面写 ...

  2. 圣思源Java视频36节练习源码分享(自己的190+行代码对比老师的39行代码)

    题目: * 随机生成50个数字(整数),每个数字范围是[10,50],统计每个数字出现的次数 * 以及出现次数最多的数字与它的个数,最后将每个数字及其出现次数打印出来, * 如果某个数字出现次数为0, ...

  3. Vue.js:轻量高效的前端组件化方案

    转发一篇尤老师对vue.js的介绍,了解vue.js的来龙去脉.不过现在已经是2.0了,也有添加一些新的东西,当然有些东西也改了. Vue.js:轻量高效的前端组件化方案 Vue.js 是我在2014 ...

  4. Day.js 是一个轻量的处理时间和日期的 JavaScript 库

    Day.js 是一个轻量的处理时间和日期的 JavaScript 库,和 Moment.js 的 API 设计保持完全一样. 如果您曾经用过 Moment.js, 那么您已经知道如何使用 Day.js ...

  5. 一个只有99行代码的JS流程框架

    张镇圳,腾讯Web前端高级工程师,对内部系统前端建设有多年经验,喜欢钻研捣鼓各种前端组件和框架. 最近一直在想一个问题,如何能让js代码写起来更语义化和更具有可读性. 上周末的时候突发奇想,当代码在运 ...

  6. Vue.js:轻量高效的前端组件化方案(转载)

    摘要:Vue.js通过简洁的API提供高效的数据绑定和灵活的组件系统.在前端纷繁复杂的生态中,Vue.js有幸受到一定程度的关注,目前在GitHub上已经有5000+的star.本文将从各方面对Vue ...

  7. 【转】Vue.js:轻量高效的前端组件化方案

    摘要:Vue.js通过简洁的API提供高效的数据绑定和灵活的组件系统.在前端纷繁复杂的生态中,Vue.js有幸受到一定程度的关注,目前在GitHub上已经有5000+的star.本文将从各方面对Vue ...

  8. ES6躬行记(4)——模板字面量

    模板字面量(Template Literal)是一种能够嵌入表达式的格式化字符串,有别于普通字符串,它使用反引号(`)包裹字符序列,而不是双引号或单引号.模板字面量包含特定形式的占位符(${expre ...

  9. 轻量高效的开源JavaScript插件和库 【转】

    图片 布局 轮播图 弹出层 音频视频 编辑器 字符串 表单 存储 动画 时间 其它 加载器 构建工具 测试 包管理器 CDN 图片 baguetteBox.js - 是一个简单易用的响应式图像灯箱效果 ...

随机推荐

  1. SQL:将字符串以特定字符分割并返回Table

    split 语法 ALTER FUNCTION [dbo].[F_SPLIT] ( @str VARCHAR(MAX) , ) ) /********************************* ...

  2. python生成器和迭代器

    生成器:具有生成能力的对象 迭代器:具有取值功能的对象 def func(): yield 1 yield 2 yield 3 ret = func() #func()函数体称为生成器 r=ret._ ...

  3. mysql的sql_mode 模式修改 my.cnf

    1. sql_mode模式 mysql数据库的中有一个环境变量sql_mode,定义了mysql应该支持的sql语法,数据校验等!我们可以通过以下方式查看当前数据库使用的sql_mode: mysql ...

  4. Web前端之html_day1

    1.html结构 1 2 3 4 5 6 7 8 9 10 <!DOCTYPE html>   <html lang="en"> <head> ...

  5. Linux下查找文件命令——find

    find [在哪个目录下查找] -name <文件名> 1.场景:当你知道了某个文件的文件名,而不知道这个文件放到哪个文件夹,甚至是层层套嵌的文件夹里, 也可以使用find命令来查找,如: ...

  6. AsyncTask下载网络图片的简单应用

    1.imageTest package lpc.com.asynctaskdemo; import android.app.Activity; import android.graphics.Bitm ...

  7. Selenium2+python自动化24-js处理富文本(带iframe)

    前言 上一篇Selenium2+python自动化23-富文本(自动发帖)解决了富文本上iframe问题,其实没什么特别之处,主要是iframe的切换,本篇讲解通过js的方法处理富文本上iframe的 ...

  8. 如何在spark中读写cassandra数据 ---- 分布式计算框架spark学习之六

    由于预处理的数据都存储在cassandra里面,所以想要用spark进行数据分析的话,需要读取cassandra数据,并把分析结果也一并存回到cassandra:因此需要研究一下spark如何读写ca ...

  9. C语言 1 << 0 是什么意思

    1 << 0 是把1 按2进制 左移0位,结果还是 1 ,2进制 0000 00011 << 1, 是把1 按2进制 左移1位,结果是2,2进制 0000 0010

  10. strace命令介绍(转)

    原文链接:http://www.cnblogs.com/ggjucheng/archive/2012/01/08/2316692.html 简介 strace常用来跟踪进程执行时的系统调用和所接收的信 ...