分页的代码逻辑是当 total > pageSize
才会有后面的第 2,3,4,5…等等页面出现。我的需求是页码分页会携带在 url 中,每次页面跳转就相当于刷新页面,所以,会有一个初始化 pageNum 代码操作,但是,由于数据未请求回来之前,数据里因为是路由的改变,相当于页面的刷新,total
被初始化为了0,所以就会遇到一个无论怎么跳转,当前页码数一直处于1的状态 。所以我想到了一个简单粗暴的方案,就是初始时拿到 Url
中的 pageNum
,数据请求回来之后,再次将 pageNum
赋值给 current-page
,代码如下:
methods:{
getCategoryList(){
this.$req.xxxx(params).then(res=>{
//在这里,数据请求完成,并且将total赋值给了 分页器的 total之后,再去重新赋值 pageNum
// 第二次赋值是为了覆盖掉 分页器的 total不够自动为第一页的页码状态
this.pages.pageNum = this.$route.params.page.split(".html")[0] - 0;
})
}
}
created() {
if (process.client) { // 这个判断是 nuxt.js, spa 不用考虑这个
//初始化pageNum,第一次赋值是为了获取正常的页面数据
this.pages.pageNum = this.$route.params.page.split(".html")[0] - 0;
this.getCategoryList();
}
}
注意:这个方法不适合用于在监听当前页码数变化时再次请求数据,这样会导致反复发起多个请求。