vue使用provide / inject 组合刷新页面+单独组件刷新
原文鏈接:https://www.cnblogs.com/leng12/p/xiaoleng.html
一、this.$router.go(0)
相當于F5刷新,這種方法雖然代碼很少,只有一行,但是體驗很差。頁面會一瞬間的白屏,體驗不是很好;
二、location.reload()
這種也是一樣,畫面一閃,體驗不是很好,相當于頁面刷新
推薦解決方法:
三、用provide / inject 組合
原理:允許一個祖先組件向其所有子孫后代注入一個依賴,不論組件層次有多深,并在起上下游關系成立的時間里始終生效
在App.vue,聲明reload方法,控制router-view的顯示或隱藏,從而控制頁面的再次加載。
App.vue
在App.vue頁面聲明
在需要用到刷新的頁面。在頁面注入App.vue組件提供(provide)的 reload 依賴,在邏輯完成之后(刪除或添加…),直接this.reload()調用,即可刷新當前頁面。
頁面中引用
export default {inject:['reload'],methods:{update(){// 在需要用到的事件中調用this.reload();函數即可this.reload() } } }原文鏈接:https://www.cnblogs.com/leng12/p/xiaoleng.html
單獨組件刷新
開發過程中會遇到一個頁面多個組件,特定條件下,我只想刷新單個組件,不要整個頁面重載怎么辦。
使用v-if指令:如果是刷新某個子組件,則可以通過v-if指令實現。我們知道,當v-if的值發生變化時,組件都會被重新渲染一遍。因此,利用v-if指令的特性,可以達到強制刷新組件的目的。
總結:頁面的刷新分為三步
1、app.vue頁面中注入App.vue組件提供(provide)的 reload 依賴
2、頁面引用 inject:['reload']
3、將需要刷新的部分綁定 v-if
組件刷新使用vue特性v-if綁定值發生改變頁面刷新
1、給組件綁定v-if
2、更改v-if綁定值,使用$nextTick再修改
$nextTick講解:https://vue3js.cn/interview/vue/nexttick.html#%E4%B8%80%E3%80%81nexttick%E6%98%AF%E4%BB%80%E4%B9%88
總結
以上是生活随笔為你收集整理的vue使用provide / inject 组合刷新页面+单独组件刷新的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: PC端微信扫码支付二维码生成接口的调整
- 下一篇: Vue试炼3组件化