【发布时间】:2019-07-09 03:06:49
【问题描述】:
我正在使用带有 node.js 和 express 的车把,并且我有一个自定义注册的温度显示助手,我想从页面 URL 访问查询参数。
帮助程序背后的概念是根据?tempFormat=F 或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 的任何使用。
有谁知道如何在不使用全局的情况下从把手自定义助手访问请求对象?
【问题讨论】:
-
在相关说明中,有人知道是否有一个讨论车把问题的论坛,在那里它可能更有可能找到车把专家(因为没有关于这个问题的活动)?跨度>
-
location.pathname.indexOf('tempFormat=F') -
@raidendev - 这不是浏览器,它是运行 node.js 的服务器,如果它是浏览器并且我正在尝试,它会在
location.search,而不是location.pathname避免使用全局变量,这样多个请求就不会出现问题。
标签: javascript mustache handlebars.js