作者:violet | 来源:互联网 | 2023-09-15 14:08
一.全页面刷新
1.修改 App.vue,代码如下:
重点如下图所示:
![](https://img.php1.cn/3cd4a/18ace/696/1d8e759bd3e6bbec.jpeg)
2.到需要刷新的页面使用 inject 进行导入并引用 reload:
![](https://img.php1.cn/3cd4a/1e618/c5a/d5d40da532c3a782.png)
3.在需要进行调用的方法中调用 this.reload() 即可
![](https://img.php1.cn/3cd4a/1eebe/cd5/d67981797265d9c7.webp)
二、局部刷新
1.定义一个变量 isReloadData,并将该变量绑定到需要刷新的标签上 :
![](https://img.php1.cn/3cd4a/1eebe/cd5/857a46d091981bac.webp)
![](https://img.php1.cn/3cd4a/1eebe/cd5/011ac27956d007f0.webp)
2.定义局部刷新的方法 reloadPart:
![](https://img.php1.cn/3cd4a/1eebe/cd5/8170a21e8dddfd22.webp)
3.在需要执行局部刷新的方法中进行调用
![](https://img.php1.cn/3cd4a/1eebe/cd5/ff61bfdd3c0af92e.webp)
三、应用场景
- 当在页面中动态修改了某些数据,或者是 props 带过来的数据,又或者是通过 funcation 动态设置的属性,可能在修改之后不会展示最新的数据。
- 当页面数据发生了变化,但是页面渲染会出现bug,例如 el-table 组件在数据发生变化后,会出现一个空白区域。
此时,全页面刷新或者局部刷新就会派上用场,下面截图举例本人遇到的第二种情况,已通过使用全页面刷新及局部刷新解决:
1.默认全选,页面渲染正常:
![](https://img.php1.cn/3cd4a/1eebe/cd5/4283cd4bbba41b87.png)
2.勾选掉一个展示列,页面渲染正常:
![](https://img.php1.cn/3cd4a/9b0d/ae9/2d998ad7838fbf16.jpeg)
3.把勾选掉的展示列再勾选上,出现空白区域:
![](https://img.php1.cn/3cd4a/1eebe/cd5/99b88427bc9ce0dc.webp)
此时,只需要在单选的方法中调用局部刷新的方法 this.reloadPart() 即可解决,同理,全选也是如此。
4.当每次新增展示列时,表格也会出现空白区域,此时我们只需要在新增记录成功后调用全页面刷新的方法 this.reload() 即可。
总结
一.全页面刷新
1.修改 App.vue,代码如下:
重点如下图所示:
![](https://img.php1.cn/3cd4a/18ace/696/1d8e759bd3e6bbec.jpeg)
2.到需要刷新的页面使用 inject 进行导入并引用 reload:
![](https://img.php1.cn/3cd4a/1e618/c5a/d5d40da532c3a782.png)
3.在需要进行调用的方法中调用 this.reload() 即可
![](https://img.php1.cn/3cd4a/1eebe/cd5/d67981797265d9c7.webp)
二、局部刷新
1.定义一个变量 isReloadData,并将该变量绑定到需要刷新的标签上 :
![](https://img.php1.cn/3cd4a/1eebe/cd5/857a46d091981bac.webp)
![](https://img.php1.cn/3cd4a/1eebe/cd5/011ac27956d007f0.webp)
2.定义局部刷新的方法 reloadPart:
![](https://img.php1.cn/3cd4a/1eebe/cd5/8170a21e8dddfd22.webp)
3.在需要执行局部刷新的方法中进行调用
![](https://img.php1.cn/3cd4a/1eebe/cd5/ff61bfdd3c0af92e.webp)
三、应用场景
- 当在页面中动态修改了某些数据,或者是 props 带过来的数据,又或者是通过 funcation 动态设置的属性,可能在修改之后不会展示最新的数据。
- 当页面数据发生了变化,但是页面渲染会出现bug,例如 el-table 组件在数据发生变化后,会出现一个空白区域。
此时,全页面刷新或者局部刷新就会派上用场,下面截图举例本人遇到的第二种情况,已通过使用全页面刷新及局部刷新解决:
1.默认全选,页面渲染正常:
![](https://img.php1.cn/3cd4a/1eebe/cd5/4283cd4bbba41b87.png)
2.勾选掉一个展示列,页面渲染正常:
![](https://img.php1.cn/3cd4a/9b0d/ae9/2d998ad7838fbf16.jpeg)
3.把勾选掉的展示列再勾选上,出现空白区域:
![](https://img.php1.cn/3cd4a/1eebe/cd5/99b88427bc9ce0dc.webp)
此时,只需要在单选的方法中调用局部刷新的方法 this.reloadPart() 即可解决,同理,全选也是如此。
4.当每次新增展示列时,表格也会出现空白区域,此时我们只需要在新增记录成功后调用全页面刷新的方法 this.reload() 即可。
总结