站长资讯网
最全最丰富的资讯网站

带你详解vue中实现全页面或局部刷新的方法

vue中怎么实现页面刷新?下面本篇文章给大家介绍一下在vue中实现全页面刷新和局部刷新的方法,希望对大家有所帮助!

带你详解vue中实现全页面或局部刷新的方法

一.全页面刷新

1.修改 App.vue,代码如下:

<template>   <div id="app">     <router-view v-if="isRouterAlive" />   </div> </template>  <script> export default {   name: 'App',   provide() { // 父组件中返回要传给下级的数据     return {       reload: this.reload     }   },   data() {     return {       isRouterAlive: true     }   },   methods: {     reload() {       this.isRouterAlive = false       this.$nextTick(function() {         this.isRouterAlive = true       })     }   } } </script>

重点如下图所示:

带你详解vue中实现全页面或局部刷新的方法

2.到需要刷新的页面使用 inject 进行导入并引用 reload:

带你详解vue中实现全页面或局部刷新的方法

3.在需要进行调用的方法中调用 this.reload() 即可

带你详解vue中实现全页面或局部刷新的方法

二、局部刷新

1.定义一个变量 isReloadData,并将该变量绑定到需要刷新的标签上 :

带你详解vue中实现全页面或局部刷新的方法

带你详解vue中实现全页面或局部刷新的方法

2.定义局部刷新的方法 reloadPart:

带你详解vue中实现全页面或局部刷新的方法

3.在需要执行局部刷新的方法中进行调用

带你详解vue中实现全页面或局部刷新的方法

三、应用场景

  • 当在页面中动态修改了某些数据,或者是 props 带过来的数据,又或者是通过 funcation 动态设置的属性,可能在修改之后不会展示最新的数据。
  • 当页面数据发生了变化,但是页面渲染会出现bug,例如 el-table 组件在数据发生变化后,会出现一个空白区域。

此时,全页面刷新或者局部刷新就会派上用场,下面截图举例本人遇到的第二种情况,已通过使用全页面刷新及局部刷新解决:

1.默认全选,页面渲染正常:

带你详解vue中实现全页面或局部刷新的方法

2.勾选掉一个展示列,页面渲染正常:

带你详解vue中实现全页面或局部刷新的方法

3.把勾选掉的展示列再勾选上,出现空白区域:

带你详解vue中实现全页面或局部刷新的方法

此时,只需要在单选的方法中调用局部刷新的方法 this.reloadPart() 即可解决,同理,全选也是如此。

4.当每次新增展示列时,表格也会出现空白区域,此时我们只需要在新增记录成功后调用全页面刷新的方法 this.reload() 即可。

赞(0)
分享到: 更多 (0)