快递,
假设我在http://localhost:3000/search?q=foo&sort=asc
在我的模板中,如何使用其他参数打印链接(例如下一个分页链接):
search.dust
<a rel="next" href="{! append page=2 !}">Next results</a>
-
当然,我可以:
<a rel="next" href="{currentUrl}&page=2">Next results</a>
但由于http://localhost:3000/search
/ ?
问题我在&
时无效。
谢谢
答案 0 :(得分:2)
我made a dust helper为此。我称之为{@query}
,这是它的签名:
{@query string="que=ry&str=ing"/}
它将que=ry&str=ing
与实际req.query
参数合并,因此在上一个示例中,我们在http://localhost:3000/search?q=foo&sort=asc
上:
<a rel="next" href="?{@query string="page=2"/}">Next</a>
将输出:
<a rel="next" href="?q=foo&sort=asc&page=2">Next</a>
-
实施如下(在中间件内部可以访问req.query
):
var dust = require('dustjs-linkedin');
var _ = require('underscore');
var qs = require('querystring');
app.use(function(req, res, next) {
//
// Query helper for dust
//
// Merge querystring parameters to the current req.query
//
// Suppose we are on localhost:3000/search?q=foo :
// - {@query string=""/} will output q=foo
// - {@query string="bar=baz"/} will output q=foo&bar=baz
// - {@query string="q=fooo&bar=baz"/} will output q=fooo&bar=baz (notice fooo takes precedence)
//
dust.helpers.query = function (chunk, ctx, bodies, params) {
var str = dust.helpers.tap(params.string, chunk, ctx);
// Parse string="" parameter
var o = qs.parse(str);
// Merge with req.query
o = _.extend({}, req.query, o);
return chunk.write(qs.stringify(o));
}
next();
});