Node.js 如何将mongoose paginate v2与多个过滤器一起使用
我使用Monggose-paginate-v2对nodejs进行分页,但是我对如何将此库与多个筛选器或查询一起使用存在问题 我的代码Node.js 如何将mongoose paginate v2与多个过滤器一起使用,node.js,mongodb,mongoose,Node.js,Mongodb,Mongoose,我使用Monggose-paginate-v2对nodejs进行分页,但是我对如何将此库与多个筛选器或查询一起使用存在问题 我的代码 exports.allData = (req, res, next) => { const { page, size, title, active } = req.query; var condition = title ? { title: { $regex: new RegExp(title), $options: "i" }
exports.allData = (req, res, next) => {
const { page, size, title, active } = req.query;
var condition = title ? { title: { $regex: new RegExp(title), $options: "i" } } : {};
var condition2 = active ? { active: { $regex: new RegExp(active), $options: "i" } } : {};
const { limit, offset } = getPagination(page, size);
var options = {
populate: [{
path: 'category',
select: 'name'
}],
sort: ({ createdAt: -1 })
};
Article.paginate(condition, condition2, { offset, limit, options })
.then((data) => {
res.send({
totalItems: data.totalDocs,
articles: data.docs,
totalPages: data.totalPages,
currentPage: data.page - 1,
});
})
.catch((err) => {
logger.error(req.method + ": " + req.originalUrl + ", message: " + err.message)
next(createError.InternalServerError())
});
};
我在一行中使用条件,条件2,它不起作用。之前谢谢。谢谢你的工作。但是如果“active”字段是布尔值呢?
pass conditional query as shown below
exports.allData = (req, res, next) => {
const { page, size, title, active } = req.query;
// query documents based on condition
let query={};
if(title){
query.title={ $regex: new RegExp(title), $options: "i" }
}
if(active){
query.active={ $regex: new RegExp(active), $options: "i" }
}
const { limit, offset } = getPagination(page, size);
var options = {
populate: [{
path: 'category',
select: 'name'
}],
sort: ({ createdAt: -1 })
};
Article.paginate(query, { offset, limit, options })
.then((data) => {
res.send({
totalItems: data.totalDocs,
articles: data.docs,
totalPages: data.totalPages,
currentPage: data.page - 1,
});
})
.catch((err) => {
logger.error(req.method + ": " + req.originalUrl + ", message: " + err.message)
next(createError.InternalServerError())
});
};