我有从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();
});发布于 2019-02-10 09:56:21
我就是这样做过滤器的。重点石板。下面是我的待办事项模型
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,
});
});
};发布于 2018-07-19 04:36:19
您可以使用这样的过滤器:
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函数。看这里。
https://stackoverflow.com/questions/46059600
复制相似问题