1.場景
在處理列表時,常常有刪除一條數(shù)據(jù)或者新增數(shù)據(jù)之后需要重新刷新當(dāng)前頁面的需求。
2.遇到的問題
- 用vue-router重新路由到當(dāng)前頁面耻煤,頁面是不進(jìn)行刷新的
2.采用window.reload()昼伴,或者router.go(0)刷新時,整個瀏覽器進(jìn)行了重新加載溯壶,閃爍及皂,體驗(yàn)不好
3.解決方法
provide / inject 組合
作用:允許一個祖先組件向其所有子孫后代注入一個依賴甫男,不論組件層次有多深,并在起上下游關(guān)系成立的時間里始終生效验烧。
App.vue:
聲明reload方法板驳,控制router-view的顯示或隱藏,從而控制頁面的再次加載
<template>
<div id="app" class="iconfont">
<router-view v-if="isRouterAlive"></router-view>
</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>
在頁面注入App.vue組件提供(provide)的 reload 依賴碍拆,在邏輯完成之后(刪除或添加...),直接this.reload()調(diào)用若治,即可刷新當(dāng)前頁面。
<template>
<el-button v-show="showreturn" class="returnBtn" plain icon="el-icon-arrow-left" @click="backmap">返回</el-button>
</template>
<script>
export default {
inject:["reload"],
methods: {
backmap() {
this.reload();
}
}
}
</script>
4.provide / inject 用法
provide:選項(xiàng)應(yīng)該是一個對象或返回一個對象的函數(shù)感混。該對象包含可注入其子孫的屬性端幼。
inject:一個字符串?dāng)?shù)組,或一個對象弧满,對象的 key 是本地的綁定名
提示:provide 和 inject 綁定并不是可響應(yīng)的婆跑。這是刻意為之的。如果你傳入了一個可監(jiān)聽的對象庭呜,那么其對象的屬性還是可響應(yīng)的滑进。