element-plus分页 项目中 列表页 页码总是回到1~

你们好,我是金金金。

场景

  • 首先我是在列表页,然后我首先点击第二页,使之页面数据显示第二页的,此时我点击新增,再次点击返回,结果列表页的页面数据是在第二页 这个没问题,但是页码回到了第一页,我想要的是 页面也继续保持 第二页。

排查

可以看到我这里是通过v-if来显示控制隐藏的

我们来看看returnTo到底什么呢?

  • 可以很清晰的看见就是改变了routerType的值,从而根据逻辑动态显示隐藏页面

造成error的原因

  • 排查中发现,导致页码回到第一页的原因就是v-if渲染所造成,因为它会让页面重新渲染。我尝试过 点击新增操作时,把当前的页码对象传递给子组件,然后我子组件里面点击返回时,再把页面对象传递给父组件从而实现记录保持住页码,但是也依旧无效,即使页码是对的,依然回到第一页。

解决

  • 我们知道导致问题的原因就是v-if所导致,那么我们就采用v-show的方式

我这里列表页采用的是v-show,里面的子组件是v-if(v-show 加载列表页的时候会同时把子组件加载了,导致点击编辑的时候数据赋值不上去)

  • 此时列表页采用的v-show,也不需要给Content组件传递页面数据了。

  • Content组件点击返回触发的事件

    • 通知父组件改变状态
  • 然后index列表页组件 改变状态即可

注意:可能有细心的小伙伴就发现了returnTo函数怎么没调用获取列表数据的函数呢?那修改了数据岂不是不会更新? 因为我这里修改 或者新增 操作成功的时候我使用emit向父组件发射了事件 动态更新了列表,这样做的好处是如果用户没有新增或者编辑 则不调用接口获取数据。所以不需要在returnTo函数里面去调用获取列表数据的函数。

总结

原因就是我列表页用了v-if重新渲染导致页码总是回到1,采用v-show方式即可。

  • 编写有误还请大佬指正,万分感谢。
相关推荐
ssshooter1 小时前
Tauri 项目实践:客户端与 Web 端的授权登录实现方案
前端·后端·rust
兆子龙1 小时前
【React】19 深度解析:掌握新一代 React 特性
前端·架构
Moment2 小时前
MinIO已死,MinIO万岁
前端·后端·github
无双_Joney2 小时前
心路散文 - 转职遇到AI浪潮,AIGC时刻人的价值是什么?
前端·后端·架构
有意义2 小时前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
小怪点点2 小时前
vue3使用
前端·vue.js
Bigger3 小时前
CSS 这些年都经历了什么?一次看懂 CSS 的演化史
前端·css·前端工程化
DevUI团队3 小时前
🚀 【Angular】MateChat V20.2.2版本发布,新增8+组件,欢迎体验~
前端·javascript·人工智能
嚴寒3 小时前
前端配环境配到崩溃?这个一键脚手架让我少掉了一把头发
前端·react.js·架构
DevUI团队3 小时前
🚀 MateChat V1.11.0 震撼发布!新增工具按钮栏组件及体验问题修复,欢迎体验~
前端·javascript·人工智能