Hogan模板

基础示例
var hogan = require('hogan');
var template = '{{message}}';
var context = {message: 'Hello template!'};
var template = hogan.compile(template);

console.log(template.render(context));
//输出结果:Hello template

标签语法

  • {{message}}    有转义功能
  • {{{message}}}    没有转义功能
  • {{! This is a comment}}    注释
  • {{#students}} some code {{/students}}    遍历students变量
  • {{^students}} some text  {{/students}}    用以students变量不存在时,显示提示文本
var hogan = require('hogan');
var template = '{{#students}}'
			 + '<p>Name: {{name}}, Age: {{age}} years old</p>'
			 + '{{/students}}';
var context = {
	students: [
		{ name: 'Jane Narwhal', age: 21 },
		{ name: 'Rick LaRue', age: 26 }
	]
};
var template = hogan.compile(template);

console.log(template.render(context));
//输出结果:<p>Name: Jane Narwhal, Age: 21 years old</p><p>Name: Rick LaRue, Age: 26 years old</p>
var hogan = require('hogan');
var template = '{{^students}}'
			 + 'No students found'
			 + '{{/students}}';
var context = {
	_students: [
		{ name: 'Jane Narwhal', age: 21 },
		{ name: 'Rick LaRue', age: 26 }
	]
};
var template = hogan.compile(template);

console.log(template.render(context));
//输出结果:No students found

模板重用

var hogan = require('hogan');
var studentTemplate = '<p>Name: {{name}}, '
					+ 'Age: {{age}} years old</p>';
var mainTemplate = '{{#students}}'
				+ '{{>student}}'
				+ '{{/students}}';
var context = {
	students: [{
		name: 'Jane Narwhal',
		age: 21
	},{
		name: 'Rick LaRue',
		age: 26
	}]
};
var template = hogan.compile(mainTemplate);
var partial = hogan.compile(studentTemplate);
var html = template.render(context, {student: partial});
console.log(html);
//输出结果:<p>Name: Jane Narwhal, Age: 21 years old</p><p>Name: Rick LaRue, Age: 26 years old</p>







转载于:https://my.oschina.net/lhplj/blog/360298

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值