Vue中的刷新的几种方法

川长思鸟来 2023-02-28 11:13 23阅读 0赞

1.场景

在处理列表时,常常有删除一条数据或者新增数据之后需要重新刷新当前页面的需求。

2.遇到的问题

  1. 用vue-router重新路由到当前页面,页面是不进行刷新的

2.采用window.reload(),或者router.go(0)刷新时,整个浏览器进行了重新加载,闪烁,体验不好

3.解决方法

provide / inject 组合

作用:允许一个祖先组件向其所有子孙后代注入一个依赖,不论组件层次有多深,并在起上下游关系成立的时间里始终生效。

在app.vue里添加:

  1. <router-view v-if="isRouterAlive"></router-view>
  2. <template>
  3. <div id="app">
  4. <router-view v-if="isRouterAlive"></router-view>
  5. </div>
  6. </template>
  7. <script type="module">
  8. export default {
  9. provide () { //父组件中通过provide来提供变量,在子组件中通过inject来注入变量。
  10. return {
  11. reload: this.reload
  12. }
  13. },
  14. data() {
  15. return {
  16. isRouterAlive : true
  17. };
  18. },
  19. methods: {
  20. reload () {
  21. this.isRouterAlive = false; //先关闭,
  22. this.$nextTick(function () {
  23. this.isRouterAlive = true; //再打开
  24. })
  25. }
  26. }
  27. }
  28. </script>
  29. <style lang="less" scoped>
  30. </style>

在需要reload的页面里添加:

  1. inject:['reload'], //注入App里的reload方法
  2. this.reload();

发表评论

表情:
评论列表 (有 0 条评论,23人围观)

还没有评论,来说两句吧...

相关阅读