我发现的主要区别是:
Handlebars添加了#if, #unless, #with和#each Handlebars添加helper 编译了车把模板(小胡子也可以) 手柄支持路径 允许在块中使用{{this}}(输出当前项的字符串值) Handlebars.SafeString()(可能还有其他一些方法) 把手的速度快2到7倍 胡子支持倒立部分(即if !x…)
(如有错误,请指正。)
还有其他我忽略的主要区别吗?
我发现的主要区别是:
Handlebars添加了#if, #unless, #with和#each Handlebars添加helper 编译了车把模板(小胡子也可以) 手柄支持路径 允许在块中使用{{this}}(输出当前项的字符串值) Handlebars.SafeString()(可能还有其他一些方法) 把手的速度快2到7倍 胡子支持倒立部分(即if !x…)
(如有错误,请指正。)
还有其他我忽略的主要区别吗?
当前回答
你已经完成了很多,但是Mustache模板也可以编译。
Mustache缺少帮助程序和更高级的模块,因为它努力做到无逻辑。句柄的自定义助手可能非常有用,但通常会在模板中引入逻辑。
Mustache有许多不同的编译器(JavaScript、Ruby、Python、C等)。Handlebars开始于JavaScript,现在有像django-handlebars, Handlebars .java, Handlebars -ruby, lightncandy (PHP)和Handlebars -objc这样的项目。
其他回答
在这里你可以看到一些速度测试不同的胡子vs车把。髭须在内存中缓存模板,不需要任何用户的努力,这就是为什么我运行它一次。比胡子慢三倍。文件系统缓存可能会减慢开发速度,最终结果可能与单次运行相当。不要盲目相信这些言论,尤其是速度。(php速度很快,因为启用了opcache+jit)
你已经完成了很多,但是Mustache模板也可以编译。
Mustache缺少帮助程序和更高级的模块,因为它努力做到无逻辑。句柄的自定义助手可能非常有用,但通常会在模板中引入逻辑。
Mustache有许多不同的编译器(JavaScript、Ruby、Python、C等)。Handlebars开始于JavaScript,现在有像django-handlebars, Handlebars .java, Handlebars -ruby, lightncandy (PHP)和Handlebars -objc这样的项目。
我觉得其中一个提到的缺点“把手”不是真的有效了。
java现在允许我们为客户端和服务器端共享相同的模板语言,这对于拥有1000多个组件的大型项目来说是一个巨大的胜利,这些组件需要为SEO提供服务器端渲染
看看https://github.com/jknack/handlebars.java
注意:这个答案已经过时了。发布的时候是这样,但现在不是了。
Mustache有许多语言的解释器,而Handlebars只有Javascript。
-除了对车把使用"this",对mustache使用变量块内的嵌套变量,你也可以对mustache使用块内的嵌套点:
{{#variable}}<span class="text">{{.}}</span>{{/variable}}