将(查询字符串)参数附加到当前URL

时间:2013-07-21 19:57:35

标签: express dust.js

快递,

假设我在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 / ?问题我在&时无效。

谢谢

1 个答案:

答案 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();
});