我可以向你保证,我现在已经对我的显示器大喊大叫,花了几个小时来理解这一点。 首先,我无法理解像手把一样的模板引擎不能做简单的比较功能的概念。
无论如何。我有这个辅助功能,当你在这里看到的时候添加到各个路线时效果很好。但是我真的想将它作为全局函数添加到由express创建的 app.js 文件中。我可以向你保证,辅助函数的GITHub示例不起作用。
真的很感激任何帮助。
我的index.js文件。
/* GET home page. */
router.get('/', function(req, res, next) {
Coupon.find(function(err, docs)
{
res.render('main/index', {
title: 'Coupon Site new for all',
coupons: docs,
//helpers
helpers: {
eq: function (v1, v2) {
return v1 === v2;
},
ne: function (v1, v2) {
return v1 !== v2;
},
lt: function (v1, v2) {
return v1 < v2;
},
gt: function (v1, v2) {
return v1 > v2;
},
lte: function (v1, v2) {
return v1 <= v2;
},
gte: function (v1, v2) {
return v1 >= v2;
},
and: function (v1, v2) {
return v1 && v2;
},
or: function (v1, v2) {
return v1 || v2;
}
},
});
});
});
在app.js中显然我应该可以做这样的事情。文档中没有的内容,我认为我应该以某种方式导入 index.js中的hbs
变量
var hbs = exphbs.create({
// Specify helpers which are only registered on this instance.
helpers: {
foo: function () { return 'FOO!'; },
bar: function () { return 'BAR!'; }
}
});
答案 0 :(得分:0)
来自 ExpressHandlebars documentation 的示例:
var express = require('express');
var exphbs = require('express-handlebars');
var app = express();
var hbs = exphbs.create({
// Specify helpers which are only registered on this instance.
helpers: {
foo: function () { return 'FOO!'; },
bar: function () { return 'BAR!'; }
}
});
app.engine('handlebars', hbs.engine);
app.set('view engine', 'handlebars');
app.get('/', function (req, res, next) {
res.render('home', {
showTitle: true,
// Override `foo` helper only for this rendering.
helpers: {
foo: function () { return 'foo.'; }
}
});
});
app.listen(3000);
那么你要为gt()
,lt()
等全局范围做些什么:在hbs
(===将它们传递给exphbs.create()
)变量中声明它们。
在handlebars
内传递render()
属性可让您<{>>覆盖在hbs
内定义的助手。