詳解解決Vue相同路由參數(shù)不同不會(huì)刷新的問題
通常情況下我們喜歡設(shè)置keepAlive 包裹 router-view
<div id="app">
<keep-alive>
<router-view></router-view>
</keep-alive>
</div>
同時(shí)在created 中觸發(fā)請(qǐng)求,在路由參數(shù)不同的情況下并不會(huì)執(zhí)行對(duì)應(yīng)的操作。
解決方法:
1、給 router-view 設(shè)置 key 屬性為路由的完整路徑
<keep-alive> <router-view :key="$route.fullPath"></router-view> </keep-alive>
這種方法我覺得應(yīng)該是一勞永逸的方法,可能對(duì)性能造成一定損耗。不適用于一個(gè)tab切換路由并加載列表的組件,會(huì)造成頁(yè)面白屏,dev模式不會(huì)自動(dòng)刷新,是個(gè)坑
2、官方給出的方法是通過 watch 監(jiān)聽路由變化,做判斷路由路徑然后調(diào)用響應(yīng)的方法
watch: {
'$route' () {
if (this.$route.path === 'test') {
this.test();
}
}
}
watch: {
'id': {
handler: 'test',
//調(diào)用方法
immediate: true,
//進(jìn)入立即執(zhí)行一次
}
},
這兩種方法推薦第一種,第二種需要先對(duì)參數(shù)id進(jìn)行賦值
3、通過組件導(dǎo)航守衛(wèi)來設(shè)置對(duì)應(yīng)的meta 屬性
beforeRouteEnter: (to, from, next) = > { // 寫在當(dāng)前組件
to.meta.keepAlive = false
next()
},
beforeRouteLeave: (to, from, next) = > { //寫在前一個(gè)組件
to.meta.keepAlive = false
next()
},
個(gè)人比較喜歡第一種方法
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue保持用戶登錄狀態(tài)(各種token存儲(chǔ)方式)
本文主要介紹了Vue保持用戶登錄狀態(tài)(各種token存儲(chǔ)方式),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
vue動(dòng)態(tài)綁定background的方法
background是background-color,background-image,background-repeat,background-attachment,background-position,background-size等屬性的縮寫,本文我用動(dòng)態(tài)綁定background-image來舉例,感興趣的朋友跟隨小編一起看看吧2023-10-10
vue父組件點(diǎn)擊觸發(fā)子組件事件的實(shí)例講解
下面小編就為大家分享一篇vue父組件點(diǎn)擊觸發(fā)子組件事件的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2018-02-02

