我正在使用Jaggery.js编写 Web 应用程序并caramel用作 MVC 框架。Caramel 使用 Handlebars 作为渲染引擎,这样我们就可以使用 Handlebars 提供的任何内置帮助器,例如{{#each}}, {{#if}}等。
但是如何编写自定义助手并在焦糖中注册,以便焦糖可以在模板中使用它呈现?
有没有这方面的样本?
提前致谢!
我正在使用Jaggery.js编写 Web 应用程序并caramel用作 MVC 框架。Caramel 使用 Handlebars 作为渲染引擎,这样我们就可以使用 Handlebars 提供的任何内置帮助器,例如{{#each}}, {{#if}}等。
但是如何编写自定义助手并在焦糖中注册,以便焦糖可以在模板中使用它呈现?
有没有这方面的样本?
提前致谢!
我找到了一种在焦糖中注册车把助手的方法,它可以工作,但不确定是否是正常和正确的解决方案。
我正在做的是在 caramel theme.js (jaggeryapps\myapp\themes\mytheme\theme.js) 中注册助手,代码如下:
var engine = caramel.engine('handlebars', (function () {
return {
partials: function (Handlebars) {
var theme = caramel.theme();
var partials = function (file) {
(function register(prefix, file) {
var i, length, name, files;
if (file.isDirectory()) {
files = file.listFiles();
length = files.length;
for (i = 0; i < length; i++) {
file = files[i];
register(prefix ? prefix + '.' + file.getName() : file.getName(), file);
}
} else {
name = file.getName();
if (name.substring(name.length - 4) !== '.hbs') {
return;
}
file.open('r');
Handlebars.registerPartial(prefix.substring(0, prefix.length - 4), file.readAll());
file.close();
}
})('', file);
};
partials(new File(theme.resolve('partials')));
Handlebars.registerHelper('my-for', function(n, block) {
var ret = '';
for(var i = 0; i < n; ++i) {
ret += block.fn(i);
}
return ret;
});
},
};
}()));