我正在使用带有 Node.js 和 Express 的车把,并且我有一个用于温度显示的自定义注册助手,我希望能够从页面 URL 访问查询参数。
帮助器背后的概念是根据是否自动处理华氏度到摄氏度的转换?tempFormat=F
or tempFormat=C
是否在 URL 中。这是我想要的自定义助手的伪代码:
hbs.registerHelper("formatTemp", function(temp) {
if (query parameter says to use Fahrenheit) {
temp = toFahrenheitStr(temp);
}
return temp;
});
所以,我希望我的模板看起来像这样:
{{#each temperatures}}
<div class="row {{{stripes @index}}}">
<div class="time">{{prettifyDate t}}</div>
<div class="atticTemp">{{formatTemp atticTemp}}</div>
<div class="outsideTemp">{{formatTemp outsideTemp}}</div>
<div class="spacer"></div>
</div>
{{/each}}
我现在正在通过拉动来解决这个问题request.query.tempFormat
并将其放入提供给模板渲染的数据中:
app.get('/debug', function(request, response) {
var tempData = {
temperatures: data.temperatures,
units: request.query.tempFormat || "C"
};
response.render('debug', tempData);
});
然后,将数据传递到模板中:
{{#each temperatures}}
<div class="row {{{stripes @index}}}">
<div class="time">{{prettifyDate t}}</div>
<div class="atticTemp">{{formatTemp atticTemp ../units}}</div>
<div class="outsideTemp">{{formatTemp outsideTemp ../units}}</div>
<div class="spacer"></div>
</div>
{{/each}}
但是,这看起来很混乱,因为我必须将温度单位传递给每个模板渲染调用,然后我必须将它们放入我希望温度显示使用的每个模板中。它们已经位于请求对象中了。那么,我想弄清楚如何从车把自定义辅助函数访问请求对象?这样,我可以为每个渲染保存代码并在每个模板中保存代码并拥有tempFormat
查询参数会自动应用于任何使用formatTemp
在我的模板中。
有谁知道如何在不使用全局的情况下从车把自定义助手访问请求对象?