我有充分的文本搜索从梯形校正模型返回结果。问题是,我使用model.find()
产生这些结果。我想分页这些结果,但我不能找到一种方法,与$text
使用.paginate()
。有没有猫鼬的全文搜索与梯形分页集成,甚至分页从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();
});
您可以使用像这样的过滤器:
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。
这是我能够做到的过滤器。 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,
});
});
};