1.ejs (写法有点类jsp/php)
Node 开源模板的选择很多,但推荐像我这样的老人去用 EJS,有 Classic ASP/PHP/JSP 的经验用起 EJS 来的确可以很自然,也就是说,你能够在 <%…%> 块中安排 JavaScript 代码,利用最传统的方式 <%=输出变量%>(另外 <%-输出变量是不会对 & 等符号进行转义的)
2. jade
jade全新的
Jade有两点是超出传统模板技术的。
第一、简洁。
注意,简洁并非单指更少的符号,而是看是否能match你的需要。Jade强制的缩进格式能凸显html的结构,而对于前端来说,最重要的任务恰恰是处理结构,而不像一般的html author那样是处理内容。反过来说,假如你的主要任务是处理内容,比如写作blog之类的,那你应该用wiki或者markdown之类的,而不应该用Jade。
第二、html-aware
传统模板技术其实是通用模板,即模板引擎并不care你输出的是html还是其他格式的文本。而Jade专为HTML设计,因此可以做许多传统模板做不到的专门针对html的优化。举个几个简单的例子:
- 决定如何输出属性(当属性赋值为null/false时不输出属性,为true时只需属性不需要值,这在传统模板里写起来很麻烦、代码难看易出错)
- 自动产生well-formed结构(甚至可决定是否要输出结束标签,而传统模板理论上也做不到这点,除非引入额外的html parse或tidy)
- 换行处理,避免产生额外的空白节点
- 对输出的变量自动进行特殊字符的encode
123456789101112 !!!htmlheadtitle #{title}meta(charset="UTF-8")bodydiv.description #{description}ul- each data in datasli.item(id='item_'+data.index)span= data.timea.art(href=data.url)= data.title
3.handlebars
|
|
总结:
Jade 很简洁,表达能力也很强,但不够直观,学习和适应成本不低。
Jade 处理模板时计算量大,在没有缓存的情况下性能低是肯定的。
Jade 对于一个不擅长前端、喜欢Bootstrap和Ctrl c + v 实在不能提高开发效, 性能瓶颈
Ejs 适用于写JSP/PHP后台的人使用,上手快
Handlebars 更接近前端的模版引擎,使用方便顺手