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,如果不是,我只想渲染索引。
我的问题很简单:这是解决此问题的好方法吗?或者我应该将其他地方移到另一条路线吗?
我能改善这一点吗?
答案 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
});
});
});