如何改进路由中的if语句[Node.js]

时间:2015-01-13 00:26:56

标签: javascript jquery node.js express

app.get('/dashboard/:page/:param',function(req, res) {
    var page = parseInt(req.param("page"));
    var param = req.param('param');

    data = {};
    data.page = page;

    if (!param) {
        data.nextPage = page + 1;
        data.prevPage = page - 1;

        MyModel.find().sort('brand').skip((page-1)*11).limit(11).exec(function(err, result) {
            res.render('index1', {
                data: data,
                result: result,
            });
        });
    } 
    else {
        data.nextPage = page + 1 + '/' + encodeURIComponent(param);
        data.prevPage = page - 1 + '/' + encodeURIComponent(param);

        MyModel.find({
               _id: param
            }).sort('brand').skip((page-1)*11).limit(11).exec(function(err, result) {
            res.render('index2', {
                data: data,
                result: result,
            });
        });
    }
});

我有这条路线,而且我用它来渲染两页。

如果页面有一个参数,我想在我的数据库中找到id并渲染de index2,如果不是,我只想渲染索引。

我的问题很简单:这是解决此问题的好方法吗?或者我应该将其他地方移到另一条路线吗?

我能改善这一点吗?

1 个答案:

答案 0 :(得分:0)

这对你来说看起来更干净吗?

app.get('/dashboard/:page/:param', function (req, res) {
  var page = parseInt(req.param("page"));
  var param = req.param('param');

  data = {
    page: page,
    nextPage: page + 1 + param ? '/' + encodeURIComponent(param) : null,
    prevPage: page - 1 + param ? '/' + encodeURIComponent(param) : null
  };

  MyModel.find(param ? {_id: param} : undefined)
    .sort('brand')
    .skip((page - 1) * 11)
    .limit(11)
    .exec(function (err, result) {
      res.render(param ? 'index2' : 'index1', {
        data: data,
        result: result
      });
    });
});