H5 Handlebars的简单使用
扫码关注公众号,不定期更新干活
web 开发中,js 解析JSON 是经常的事情。非常繁琐。handlebars 使用了模版,只要你定义一个模版,提供一个json对象,handlebars 就能吧json对象放到你定的模版中,非常方便好用!
- H5中都是Html,在这里我们没有el标签。所以我们只能借助模板。好处上面已经介绍了。
H5中循环遍历
- 第一步:在html中定义模板,将后台的json放在模板里。
<script id="task-table-template" type="text/x-handlebars-template">
{{#each this}}//遍历循环的格式,相当于foreach
<a href="{{link}}">//json中的link必须是{{}}格式
<strong>
{{Obj_title}}//同上
</strong>
</a>
{{/each}}
</script>
- 第二步:在js中实例化这个模板
var myTemplate = Handlebars.compile($("#task-table-template").html());
- 第三步:将后台json传进来显示,并确定模板显示位置,下面的列子 将模板显示在class=notice_srcoll的div上
$('.notice_srcoll').html(myTemplate(data.noticeTasklist));
- 这里提到的json就是我们熟悉的json,给一个列子看看
var data = { users: [
{username: "alan", firstName: "Alan", lastName: "Johnson", email: "alan@test.com" },
{username: "allison", firstName: "Allison", lastName: "House", email: "allison@test.com" },
{username: "ryan", firstName: "Ryan", lastName: "Carson", email: "ryan@test.com" }
]};
H5中if else的使用
- handlebar中if else只支持原生态的,也就是只支持true 和 false 的判断,但是事实上我们的逻辑中很多情况下的判断并不是仅仅就true和false,这个时候我们这么办呢。先看看原生态的if else
{{#if score}}
<li>
<font>
<input type="checkbox" name="you" id="{{id}}" class="regular-checkbox big-checkbox" value="{{id}}" checked disabled/>
<label for="{{id}}"></label>
</font>
<div class="li_div">
<strong>
{{name}}
</strong>
<p>主讲老师
{{teacher}}
</p>
</div>
</li>
{{else}}
<li>
<font><input type="checkbox" name="you" id="{{id}}1" class="regular-checkbox big-checkbox" value="{{id}}" />
<label for="{{id}}1"> </label>
</font>
<div class='li_div'>
<strong>
"{{name}}"
</strong>
<p>主讲老师
{{teacher}}
</p>
</div>
</li>
{{/if}}
这里的判断就是说score未undefined null false [] 返回的都是false,在这里并不能判断分数大小。这个时候我们通过Handlebars.registerHelper用来定义Helper来对handlebars就醒扩展。
html代码
{{#compare age 20}}
<tr>
<td>{{name}}</td>
<td>{{sex}}</td>
<td>{{age}}</td>
</tr>
{{else}}
<tr>
<td>?</td>
<td>?</td>
<td>?</td>
</tr>
{{/compare}}
- js对handlebars扩展
//注册一个比较大小的Helper,判断v1是否大于v2
Handlebars.registerHelper("compare",function(v1,v2,options){
if(v1>v2){
//满足添加继续执行
return options.fn(this);
}else{
//不满足条件执行{{else}}部分
return options.inverse(this);
}
});
这里需要说明一下,在利用Handlebars.registerHelper注册事件时,如果后面的function中没有传options的话我们就可以直接调用,如果有options的话,我们需要在前面加上#,因为加上options的话是块级别的Helper。
事列一
Handlebars.registerHelper("addOne",function(index,options){
return parseInt(index)+1;
});
- 调用
<label for="checkbox-2-{{addOne @index}}"></label>
- 事列二
Handlebars.registerHelper("compare",function(v1,v2,options){
if(v1>v2){
//满足添加继续执行
return options.fn(this);
}else{
//不满足条件执行{{else}}部分
return options.inverse(this);
}
});
- 调用
{{#compare age 20}}
- 原声if还支持多级判断
{{#if name.xxx}},这样写就假设name属性是一个map,检测name属性中是否包含xxx属性。
Helper中options参数
- 这里参考网上一篇博客的案列
{{#sort ages id="ages-list" class="con" }}
<span>{{@name}}:{{this}}</span>
{{/sort}}
- 经过编译后上面这段信息被分装在options里了。下面是注册代码
//上面的信息在下面的options里
Handlebars.registerHelper("sort",function(context,options){
var i = 0,str="<div id="+ options.hash.id +" class="+ options.hash.class +">";
for(;i<context.length;i++){
str+=options.fn(context[i],{data:{name:options.data[i]}});
}
str+="</div>";
return str;
});
helper中的options包含了那些信息?
- data:可以在渲染模板时,将其传进去,如template(context, {data: data}) 。(//这里后面会涉及)
- hash : 保存写模板时,可以将一些值以key-value对的形式传进去,比如上面的div里有ID 和 classs属性,这两个都是键值对,都会存在options.hash中,这里我们可以看成是map
- fn : 方法,官方解释说“options.fn的可以被认为是被编译过的普通handlebars模板,它的调用的执行环境被认为是‘this’,所以你可以把this作为执行上下文去调用它”,这里存放了上面那个div中的闭环体。什么是闭环体?所谓闭环体就是有开有闭,上面div里那个span就是闭环体,形如这样的就是闭环体。
- inverse : 给if的block的else来用的.说白了就是给{{else}}使用的。
数据源及模板渲染
var template = Handlebars.compile($("#people-template").html());
var temp = {ages:[23,24,56,64]}
var result = template(temp,{data:["tom","jak","lili","jim"]});
/*result:
<div id="ages-list" class="con">
<span>jak:24</span>
<span>lili:56</span>
<span>jim:64</span>
</div>
模板渲染中用到
var result = template(temp,{data:["tom","jak","lili","jim"]});
就是在渲染时传入data数据.正常情况下传递一个json数据,当传两个json了,第二个json里的数据就是替换模板中的占位符的({{@…}}这种写法的占位符).str+=options.fn(context[i],{data:{name:options.data[i]}});这句话就是将模板渲染时传入的数据中的name字段付给{{@name}}这个占位符。context[i]就是传给文中{{this}}也就是相当于{{ages}}的。在渲染时一定要匹配,比如我的数据源是ages那就一定要用ages,那为什么我上面用的是{{this}},因为我在div中的ages,所以div下面的上下文this指代的就是ages.
仿each写高级list
- 模板
{{#each comments}}
<div class="comment">
<h2>{{subject}}</h2>
{{{body}}}
</div>
{{/each}}
- 在上面的模板中看出,我们遍历出的是div,div本身就是闭环体,都在我们的options.fn中,所以我们的helper就直接遍历就行了。
Handlebars.registerHelper('each', function(context, options) {
var ret = "";
for(var i=0, j=context.length; i<j; i++) {
ret = ret + options.fn(context[i]);
}
return ret;
});
根据这个我们完全可以写出更加高级的遍历
模板
{{#list nav}}
<a href="{{url}}">{{title}}</a>
{{/list}}
- helper 不难看出a 是闭环体,也就是我们传入值,options.fn中就自动有
<a></a>
,我们需要做的是加上<ul></ul>
,并在每一项上加上<li></li>
闭环体。这样就显的更加有规格了。这也是官网上提供的。
Handlebars.registerHelper('list', function(context, options) {
var ret = "<ul>";
for(var i=0, j=context.length; i<j; i++) {
ret = ret + "<li>" + options.fn(context[i]) + "</li>";
}
return ret + "</ul>";
});
H5空白处理
- 模板中的空白可以忽略,mustache声明的两边都可以,只需添加一个 ~ 字符即可。写了这个之后,这一边的所有空白都会被移除,直到最近的Handlebars表达式或这一边的非空白字符
{{#each nav ~}}
<a href="{{url}}">
{{~#if test}}
{{~title}}
{{~^~}}
Empty
{{~/if~}}
</a>
{{~/each}}
{
nav: [
{url: 'foo', test: true, title: 'bar'},
{url: 'bar'}
]
}
- 得出的结果没有换行,也没有格式化用的空白符:
<a href="foo">bar</a><a href="bar">Empty</a>
扫码关注公众号,不定期更新干活
H5 Handlebars的简单使用的更多相关文章
- 用PHP+H5+Boostrap做简单的音乐播放器(进阶版)
前言:之前做了一个音乐播放器(纯前端),意外的受欢迎,然后有人建议我把后台一起做了,正好也想学习后台,所以学了两天php(不要吐槽我的速度,慢工出细活嘛~)然后在之前的基础上也又完善了一些功能,所以这 ...
- 用H5+Boostrap做简单的音乐播放器
前言:这个是综合一下我最近在学的东西做的小Demo,到实际使用还有距离,但是用来练手巩固知识点还是不错的,最近在二刷JS书和Boostrap.css的源码,做完这个Demo也算是暂告一段落,接下来是j ...
- H5之canvas简单入门
<canvas></canvas>是html5出现的新标签,像所有的dom对象一样它有自己本身的属性.方法和事件,其中就有绘图的方法,js能够调用它来进行绘图 <canv ...
- H5的localStorage简单存储删除
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- php微信h5支付超简单!!!
本示例应用于tp3.2版本 不懂私聊我QQ:1195989301 请备注来意! 代码链接 请点击下载 密码: ekd4 不喜欢打字望谅解.....
- 基于H5的WebSocket简单实例
客户端代码: <html> <head> <script> var socket; if ("WebSocket" in window) { v ...
- Handlebars的基本用法 Handlebars.js使用介绍 http://handlebarsjs.com/ Handlebars.js 模板引擎 javascript/jquery模板引擎——Handlebars初体验 handlebars.js 入门(1) 作为一名前端的你,必须掌握的模板引擎:Handlebars 前端数据模板handlebars与jquery整
Handlebars的基本用法 使用Handlebars,你可以轻松创建语义化模板,Mustache模板和Handlebars是兼容的,所以你可以将Mustache导入Handlebars以使用 Ha ...
- Handlebars的使用方法文档整理(Handlebars.js)
Handlebars是一款很高效的模版引擎,提供语意化的模版语句,最大的兼容Mustache模版引擎, 提供最大的Mustache模版引擎兼容, 无需学习新语法即可使用; Handlebars.js和 ...
- H5+Boostrap的音乐播放器
H5+Boostrap做简单的音乐播放器 前言:这个是综合一下我最近在学的东西做的小Demo,到实际使用还有距离,但是用来练手巩固知识点还是不错的,最近在二刷JS书和Boostrap.css的源码,做 ...
随机推荐
- 哈工大计算机网络Week2-网络应用数据交换
目录 网络应用数据交换 P2P应用:原理与文件分发 纯P2P架构 文件分发:客户机/服务器 vs. P2P CS 为什么是这样的?不应该传送和发出难道是并行的??? P2P P2P文件分发典型例子:B ...
- java接口自动化(一) - 接口自动化测试整体认知 - 开山篇(超详解)
简介 了解什么是接口和为什么要做接口测试.并且知道接口自动化测试应该学习哪些技术以及接口自动化测试的落地过程.其实这些基本上在python接口自动化的文章中已经详细的介绍过了,不清楚的可以过去看看.了 ...
- infiniband 网卡驱动安装
硬件:Mellanox InfiniBand,主要包括 HCA(主机通道适配器)和交换机两部分软件:CentOS 6.4MLNX_OFED_LINUX-2.1-1.0.0-rhel6.4-x86_64 ...
- linux weblogic12.1.3.0卸载过程
主要是一开始以为跟之前版本一样有uninstall.sh,但却找不到. 最后google 才发现改了个名字,deinstall.sh 可能后面的版本都是这个脚本了吧. 先进入脚本目录,命令:cd /h ...
- Code Review最佳实践
我一直认为Code Review(代码审查)是软件开发中的最佳实践之一,可以有效提高整体代码质量,及时发现代码中可能存在的问题.包括像Google.微软这些公司,Code Review都是基本要求,代 ...
- React躬行记(9)——组件通信
根据组件之间的嵌套关系(即层级关系)可分为4种通信方式:父子.兄弟.跨级和无级. 一.父子通信 在React中,数据是自顶向下单向流动的,而父组件通过props向子组件传递需要的信息是组件之间最常见的 ...
- 从0系统学Android-2.3使用 Intent 在 Activity 之间穿梭
2.3 使用 Intent 在 Activity 之间穿梭 在上一节中我们已经学会了如何创建一个 Activity 了.对于一个应用程序来说,肯定不可能只有一个 Activity.下面就来学习多个 A ...
- Python之父新发文,将替换现有解析器
花下猫语: Guido van Rossum 是 Python 的创造者,虽然他现在放弃了"终身仁慈独裁者"的职位,但却成为了指导委员会的五位成员之一,其一举一动依然备受瞩目.近日 ...
- halcon视频教程如何学习?怎么样才能踏入机器视觉这个行业?
本人是工作八年的视觉工程师,主要从事Halcon和Visionpro视觉开发,谈谈个人对视觉学习看法: 1.HALCON是德国MVtec公司开发的一套完善的标准的机器视觉算法包,它节约了产品成本,缩短 ...
- Linux 下实践 VxLAN:虚拟机和 Docker 场景
本文首发于我的公众号 Linux云计算网络(id: cloud_dev),专注于干货分享,号内有 10T 书籍和视频资源,后台回复 「1024」 即可领取,欢迎大家关注,二维码文末可以扫. 在上篇文章 ...