关于element-ui分页器 设置current-page为初始化值为 1 时的问题

分页的代码逻辑是当 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();
	    }
	}

注意:这个方法不适合用于在监听当前页码数变化时再次请求数据,这样会导致反复发起多个请求。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现element-ui分页的实数据更新,可以使用以下步骤: 1. 在组件中定义一个变量来存储当前页数和每页显示的数据条数。 2. 监听变量的变化,当变量发生变化,重新请求数据并更新分页的总条数和当前页数。 3. 在分页组件中绑定页码和每页显示数据条数的变量,当用户点击分页,更新变量的值,触发数据更新。 下面是一个示例代码: ```html <template> <div> <el-table :data="tableData" border> <el-table-column prop="name" label="姓名"></el-table-column> <el-table-column prop="age" label="年龄"></el-table-column> </el-table> <el-pagination v-model="currentPage" :total="total" :page-size="pageSize" @size-change="handleSizeChange" @current-change="handleCurrentChange" /> </div> </template> <script> export default { data() { return { tableData: [], currentPage: 1, pageSize: 10, total: 0, }; }, watch: { currentPage: { handler() { this.getData(); }, }, pageSize: { handler() { this.currentPage = 1; this.getData(); }, }, }, mounted() { this.getData(); }, methods: { getData() { // 根据 currentPagepageSize 请求数据 // 更新 tableData 和 total }, handleSizeChange(val) { this.pageSize = val; }, handleCurrentChange(val) { this.currentPage = val; }, }, }; </script> ``` 在这个示例中,我们使用了 `watch` 来监听 `currentPage` 和 `pageSize` 的变化,当变化,重新请求数据并更新分页的总条数和当前页数。同,在分页组件中绑定了 `currentPage` 和 `pageSize` 的变量,并监听了分页的点击事件,更新变量的值,触发数据更新。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值