我有简单的分页功能,可以输出结果。
1 ... 6 7 8 9 ... 21
这些函数需要计算结果的参数是当前页数和总页数。
但是我不能将其放在我的视图(把手)中,因为如果我是对的,{{each pageArray}}
需要从后端来的数据。
但是我不能将其放在我的route.js中,因为在函数调用时,我不知道页面数或当前数。仅当我传递假数据(例如总页数= 100,当前页= 5)时,此方法才有效
我不知道如何使其工作。我不了解快递分页的工作原理,例如他们以某种方式做到了……
我的route.js
// View users
router.get("/show/:page", function (req, res, next) {
var perPage = 1
var page = req.params.page || 1
User
.find({})
.skip((perPage * page) - perPage)
.limit(perPage)
.exec(function (err, users) {
User.countDocuments().exec(function (err, count) {
if (err) return next(err)
res.render('../core/modules/users/views/userList', {
layout: "cmsLayout",
users: users,
current: page,
pages: Math.ceil(count / perPage),
helpers,
pagesArr: Array.from(Array(((Math.ceil(count / perPage)))).keys()).map(i => 1 + i),
pageArray: pagination
})
})
})
});
我的分页功能
function pagination(currentPage, nrOfPages) {
var delta = 2,
range = [],
rangeWithDots = [],
l;
range.push(1);
if (nrOfPages <= 1) {
return range;
}
for (let i = currentPage - delta; i <= currentPage + delta; i++) {
if (i < nrOfPages && i > 1) {
range.push(i);
}
}
range.push(nrOfPages);
for (let i of range) {
if (l) {
if (i - l === 2) {
rangeWithDots.push(l + 1);
} else if (i - l !== 1) {
rangeWithDots.push('...');
}
}
rangeWithDots.push(i);
l = i;
}
return rangeWithDots;
}
答案 0 :(得分:0)
通过更改解决
pagination: pagination(current, pages)
到
pagination: pagination(page, (Math.ceil(count / perPage)))
感谢@iagowp解决方案。