Node.js 如何将mongoose paginate v2与多个过滤器一起使用

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" }

我使用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" } } : {};
  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())
   });
};