使用KeystoneJS paginate进行猫鼬全文搜索

时间:2017-09-05 16:31:06

标签: mongoose pagination keystonejs

我有全文搜索返回Keystone模型的结果。问题是我使用model.find()生成这些结果。我想对这些结果进行分页,但我找不到将$text.paginate()一起使用的方法。有没有办法将猫鼬全文搜索与Keystone分页相结合,甚至是model.find()的分页结果?

修改

我已经厌倦了使用keystone.list('List').paginate().find(),但收到错误:“回调不是函数。”也许我的代码还有其他问题:

keystone.list('Document').paginate({
  page: req.query.page || 1,
  perPage: 10,
  maxPages: 6,
})
.find(
  { $text : { $search : req.query.search } },
  { score : { $meta: "textScore" } }
)
.sort({ score : { $meta : 'textScore' } })
.exec(function(err, results) {
  locals.documents = results;
  next();
});

2 个答案:

答案 0 :(得分:1)

您可以使用以下过滤器:

keystone.list('Document').paginate({
    page: req.query.page || 1,
    perPage: 10,
    maxPages: 6,
    filters: {
        $text: {
            $search: req.query.search || ''
        },
    },
    optionalExpression: {
        score: {$meta: "textScore"}
    },
})
.sort({ score : { $meta : 'textScore' } })
.exec(function(err, results) {
    locals.documents = results;
    next();
});

paginate函数会将其传递到find函数中。 See here

答案 1 :(得分:0)

这就是我设法进行过滤的方式。 Keystone boilerplate。下面是我的待办事项模型

import keystone from 'keystone';

const { Field: { Types } } = keystone;

const Todo = new keystone.List('Todo');

Todo.add({
   title: {
   type: String, required: true, default: Date.now,
 },
 description: { type: Types.Html, wysiwyg: true },
 createdAt: { type: Date, default: Date.now },
});

Todo.relationship({ path: 'users', ref: 'User', refPath: 'todos' });
Todo.schema.index({ title: 'text' });
Todo.register();

export default Todo;

和分页过滤器

export const list = (req, res) => {
const search = new RegExp(req.query.search || '', 'i');
const query = {
  title: search,
};
Todo.paginate({
   page: req.query.page || 1,
   perPage: 5,
   maxPages: 10,
   filters: {
     $or: [query],
   },
 }).sort('-createdAt').exec((err, items) => {
 if (err) return res.status(500).json(err);

   return res.json({
     data: items,
   });
 });
};