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方式即可。

  • 编写有误还请大佬指正,万分感谢。
相关推荐
jnene7 分钟前
html 时间、价格筛选样式处理
前端·css·html
slongzhang_30 分钟前
jquery 修复怪异模式html未声明“<!DOCTYPE html>”
前端·html·jquery
云水一下1 小时前
Vue.js从零到精通系列(三):组件化基础——Props、Emits、插槽与生命周期
前端·javascript·vue.js
SEO_juper2 小时前
新独立站冷启动收录全攻略:配置、推送、抓取配额优化完整手册
前端·谷歌·seo·跨境电商·外贸·geo·独立站
TinssonTai2 小时前
这个 VS Code 插件让我的 AI Coding 又快又稳 - 旧瓶装新酒
前端·人工智能·程序员
体验家2 小时前
体验家 XMPlus 网页端问卷 SDK 技术解析:用几行 JavaScript 实现精准场景触发与防打扰机制
开发语言·前端·javascript
Maimai108082 小时前
Web3 前端交易系统如何落地:从下单 UI 到 Operation 编码、签名与实时状态更新
前端·react.js·ui·架构·前端框架·web3
kidding7232 小时前
高效备忘清单工具类小程序
前端·计算机网络·微信小程序·小程序
IMPYLH3 小时前
HTML 的 <abbr> 元素
前端·算法·html
李白的天不白3 小时前
Tree-Shaking
前端