handlebars使用总结
对自己使用handlebars做一个小总结,以后忘记了,好有地方看一下,不会用的小伙伴也可以借鉴一下,写的不好。
使用
Handlebars的安装是比较简单和方便的;handlebars是一个纯JS库,因此你可以像使用其他JS脚本一样用script标签来包含handlebars.js
<script src="jquery.min.js"></script>
<script type="text/javascript" src=".js/handlebars.js"></script>
基本
html:
<-- 模板 -->
<script type="text/x-handlebars-template" id="tpl">
{{#each}}
...
{{/each}}
</script>
js:
//获取到模板
var tpl = $("#tpl").html();
//预编译模板
var template = Handlebars.compile(tpl);
//模拟数据(也可以是获取的json数据)
var context = {};
//匹配数据
var html = template(context);
//输入模板
$('body').html(html);
注 : 这是handlebars最常用的一中创建使用模式。
下面写一点handlebars的一些常用的方法,几乎是只要你用到handlebars就会用到的方法;我是100%用到了;
注:下面这些都是在模板中的使用的只有,目前只有helper是在js中定义在模板中使用。
概念和常用方法
1.block
我看每个介绍handlebars的都介绍了这个最基本最基本的东西,我也说不好,只能简单说一下了。
这个就是将模板分成块以#开头以/结束
{{#...}}{{/...}}
//例如 :
{{#each}}{{/each}}
{{#if}}{{else}}{{/if}}
2.表达式
这也是一个非常简单的一个概念,越简单的越难说,但是好理解希望你们能理解,原谅文化水平不高的我
我们想要展示数据就要用到表达式,在handlebars中的表达式就是两层大括号,括号里写上json数据中的键展现在页面上的就是对应的值 {{...}}
如果我们不想转化handlebars的数据,就是直接展示json的键我们就需要三层大括号 {{{}}}
3.判断 if and unless
handlebars中的判断很弱,弱到这能判断true和false(包括布尔值转化的例如 "",undefined,NaN。不支持 == != || && !)。handlebars提供了一个自定义helper可以自己加强if,这个后面会说到。
1.if判断(一般我使用这个)
模板:
{{#if true}}
<div>为true的时候显示<div>
{{else}}
<div>为false的时候显示<div>
{{/if}}
2.unless判断(与if是相反的)
模板:
{{#unless false}}
<div>为false的时候显示<div>
{{else}}
<div>为true的时候显示<div>
{{/unless}}
4.部分 {{#with}}{{/with}}
这种情况是返回的json数据有多个对象嵌套的问题,很好用的一个方法,
也可以直接通过对象点属性的方法找下去,既然handlebars提供了。我就说一下,用不用,看情况
json数据:
{
title : "标题1",
author: {
firstName:"王大",
lastName:"王二"
}
}
模板:
<div>
<h1>{{title}}</h1>
{{#with author}}
<p>{{firstName}}</p>
<p>{{lastName}}</p>
{{/with}}
</div>
5.遍历 {{#each}}{{/each}}
数据返回我们一个数组是很常见的问题,handlebars有专门处理数组的方法
json数据:
{name:["html","css","javaScript"]}
模板:
<ul>
{{#each name}}
<li>{{@index}} 索引<li>
<li>{{this}}</li>
{{/each}}
</ul>
注:this就是name数组中的每一个
6.注释
单行:
{{! 注释的内容 }}
多行:
{{!-- 注释的代码段--}}
7.自定义 helper
定义要在js文件中定义,使用要在模板中使用
handlebars使用Handlebars.registerHelper()方法来注册helper,
一般分为两类,一类是用来格式化数据,另一类是用来加强if
这个网址说的很详细:http://www.tuicool.com/articles/aiaqMn
时间格式化:
//时间戳处理
Handlebars.registerHelper('format', function (date,options) {
let str = new Date(date).toLocaleString();
let i = str.indexOf(' ');
let str1 = str.substr(i + 1,2);
let str2 = str.substr(i + 3,2); if (isNaN(str2)) {
if (str1 == '上午') {
str = str.replace(str.substr(i + 1,3),'0' + str.substr(i + 3,1));
}else {
str = str.replace(str.substr(i + 1,3),Number(str.substr(i + 3,1)) + 12);
}
}else{
if (str1 == '上午') {
str = str.replace(str.substr(i + 1,2),'');
}else {
if(Number(str2) == 12){
str = str.replace(str.substr(i + 1,4),'00');
}else {
str = str.replace(str.substr(i + 1,4),Number(str.substr(i + 3,2)) + 12);
}
}
}
return str;
});
if的简单加强:
//if 处理
Handlebars.registerHelper('ifCond', function(v1, v2, options) {
if(v1 == v2) {
return options.fn(this);
}
//options.inverse()这个方法就是取反的意思,相当于if的else
return options.inverse(this);
});
返回一个字符串:
Handlebars.registerHelper('valValType', function(){
//this.type 是返回的数据
var type = Handlebars.escapeExpression(this.type);
var html = `<div>1234</div>`;
if(type){
var newHtml =`<div>12345</div>`;
}else {
var newHtml = html;
}
return new Handlebars.SafeString(newHtml)
})
//用法在模板里 {{ valValType }}
handlebars使用总结的更多相关文章
- Handlebars 模板引擎之前后端用法
前言 不知不觉间,居然已经这么久没有写博客了,坚持还真是世界上最难的事情啊. 不过我最近也没闲着,辞工换工.恋爱失恋.深圳北京都经历了一番,这有起有落的生活实在是太刺激了,就如拿着两把菜刀剁洋葱一样, ...
- handlebars自定义helper的写法
handlebars相对来讲算一个轻量级.高性能的模板引擎,因其简单.直观.不污染HTML的特性,我个人特别喜欢.另一方面,handlebars作为一个logicless的模板,不支持特别复杂的表达式 ...
- handlebars.js的运用与整理
最近在做部门的技术分享网站,主要是一些文章的列表和演讲信息展示,内容比较规律,复用性较高.同事推荐了 handlebars.js.用来看看. handlebars.js是一种静态JS模板,用起来还蛮简 ...
- Express 4 handlebars 不使用layout写法
Express 4 handlebars 不使用layout写法 Express node nodejs handlebars layout 最近刚开始学习使用nodejs. 使用express搭建了 ...
- Handlebars.js的学习
写在开头的话: 在使用Ghost搭建自己的博客的时候,发现不会Handlebars.js寸步难行,所以本人决定学习下Handlebars.js,因此在此做个记录 为什么选择Handlebars.js ...
- js模版引擎handlebars.js实用教程——目录
写在开头的话: 阅读本文需要了解基本的Handlebars.js概念,本文并不是Handlebars.js基础教程,而是注重于实际应用,为读者阐述使用过程中可能会遇到的一些问题. 实际上,小菜写这篇文 ...
- Handlebars块级Helpers
1.Handlebars简单介绍: Handlebars是JavaScript一个语义模板库,通过对view和data的分离来快速构建Web模板.它采用"Logic-less templat ...
- js模版引擎handlebars.js实用教程——为什么选择Handlebars.js
返回目录 据小菜了解,对于java开发,涉及到页面展示时,比较主流的有两种解决方案: 1. struts2+vo+el表达式. 这种方式,重点不在于struts2,而是vo和el表达式,其基本思想是: ...
- handlebars.js 用 <br>替换掉 内容的换行符
handlebars.js 用 <br>替换掉 内容的换行符 JS: Handlebars.registerHelper('breaklines', function(text) { te ...
- 【前端】制作一个handlebars的jQuery插件
(function($) { var compiled = {}; $.fn.handlebars = function($srcNode, data) { // 取出模版内容 var src = $ ...
随机推荐
- mysql的 charset、collation、prefix了解
charset,即字符集. collation,用于指定数据集如何排序,以及字符串的比对规则,即排序规则. prefix,即数据库里表使用的前缀. /************************* ...
- ubuntu10.4的更新源因过期无法更新的解决方法
转载自:http://blog.csdn.net/suquan629/article/details/52333769 ubuntu10.4到2016年早已停止了更新支持,ubuntu也不再维护了.官 ...
- 《OpenCV3 计算机视觉--Python语言实现 第二版》源代码及纠错
1.源代码下载地址 <OpenCV3 计算机视觉--Python语言实现 第二版>由我们翻译,英文书名<Learning OpenCV3 Computer Vision with P ...
- IOS开发中AVFoundation中AVAudioPlayer的使用
IOS开发中如何调用音频播放组件 1.与音频相关的头文件等都在AVFoundation.h中,所以第一步是添加音频库文件: #import <AVFoundation/AVFoundation. ...
- Python装饰器学习(九步入门)
这是在Python学习小组上介绍的内容,现学现卖.多练习是好的学习方式. 第一步:最简单的函数,准备附加额外功能 ? 1 2 3 4 5 6 7 8 # -*- coding:gbk -*- '''示 ...
- Centos下关于ssh、scp与rsync设置与应用
最近应公司要求,需要对文件数据进行远程传输与备份操作,特此写了一篇文章记录下了关于ssh.scp以及rsync的应用配置全过程,可能过程太过罗嗦,但主要就是想在不遗漏每个过程的情况下对此进行阐述,希望 ...
- 屏蔽ps联网激活
屏蔽ps联网激活C:\Windows\system32\drivers\etc\host127.0.0.1 lm.licenses.adobe.com127.0.0.1 na1r.services.a ...
- 用JS的数组缓存一些东西
var cache_index = new Array(); //首页的ajax缓存 //ajax 推荐的游戏和软件 function change_tuijian(sid,div_class){ i ...
- origin从图中获得数据
有Origin的原图,即利用Origin的"copy page"功能直接拷贝到文字处理软件的数据图,对于这种图,双击用Origin打开后,双击要导出数据的权限,打开"pl ...
- 解析STL中典型的内存分配
1 vector 在C++中使用vector应该是非常频繁的,但是你是否知道vector在计算内存分配是如何么? 在c++中vector是非常类似数组,但是他比数组更加灵活,这就表现在他的大小是可以自 ...