vue使用provide / inject 组合刷新页面+单独组件刷新
原文鏈接:https://www.cnblogs.com/leng12/p/xiaoleng.html
一、this.$router.go(0)
 相當(dāng)于F5刷新,這種方法雖然代碼很少,只有一行,但是體驗(yàn)很差。頁(yè)面會(huì)一瞬間的白屏,體驗(yàn)不是很好;
二、location.reload()
 這種也是一樣,畫面一閃,體驗(yàn)不是很好,相當(dāng)于頁(yè)面刷新
推薦解決方法:
 三、用provide / inject 組合
原理:允許一個(gè)祖先組件向其所有子孫后代注入一個(gè)依賴,不論組件層次有多深,并在起上下游關(guān)系成立的時(shí)間里始終生效
 在App.vue,聲明reload方法,控制router-view的顯示或隱藏,從而控制頁(yè)面的再次加載。
App.vue
 在App.vue頁(yè)面聲明
在需要用到刷新的頁(yè)面。在頁(yè)面注入App.vue組件提供(provide)的 reload 依賴,在邏輯完成之后(刪除或添加…),直接this.reload()調(diào)用,即可刷新當(dāng)前頁(yè)面。
頁(yè)面中引用
export default {inject:['reload'],methods:{update(){// 在需要用到的事件中調(diào)用this.reload();函數(shù)即可this.reload() } } }原文鏈接:https://www.cnblogs.com/leng12/p/xiaoleng.html
單獨(dú)組件刷新
開發(fā)過(guò)程中會(huì)遇到一個(gè)頁(yè)面多個(gè)組件,特定條件下,我只想刷新單個(gè)組件,不要整個(gè)頁(yè)面重載怎么辦。
 使用v-if指令:如果是刷新某個(gè)子組件,則可以通過(guò)v-if指令實(shí)現(xiàn)。我們知道,當(dāng)v-if的值發(fā)生變化時(shí),組件都會(huì)被重新渲染一遍。因此,利用v-if指令的特性,可以達(dá)到強(qiáng)制刷新組件的目的。
總結(jié):頁(yè)面的刷新分為三步
 1、app.vue頁(yè)面中注入App.vue組件提供(provide)的 reload 依賴
 2、頁(yè)面引用 inject:['reload']
 3、將需要刷新的部分綁定 v-if
組件刷新使用vue特性v-if綁定值發(fā)生改變頁(yè)面刷新
 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
總結(jié)
以上是生活随笔為你收集整理的vue使用provide / inject 组合刷新页面+单独组件刷新的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
                            
                        - 上一篇: PC端微信扫码支付二维码生成接口的调整
 - 下一篇: java开发名言_java实现收藏名言语