vue2使用keep-alive緩存多層列表頁的方法
vue關(guān)于列表頁和詳情頁的展現(xiàn)比較讓人頭疼,在列表頁面點(diǎn)擊進(jìn)詳情頁返回以后,列表頁會重新刷新。假如在第五頁找到的數(shù)據(jù),點(diǎn)擊修改后返回又跳回第一頁了,這個(gè)時(shí)候就需要用到keep-alive緩存頁面數(shù)據(jù),但keep-alive緩存的頁面一直不會發(fā)生改變,特別是列表頁層級很多的情況下,更加復(fù)雜。
譬如我后臺的一個(gè)管理頁面,因?yàn)閿?shù)據(jù)關(guān)聯(lián)很復(fù)雜,所以做了三層列表頁嵌套,上一層點(diǎn)擊管理就可以進(jìn)行下一層的數(shù)據(jù)展現(xiàn),每一層列表頁都包含了3到4個(gè)需要循環(huán)展現(xiàn)的數(shù)據(jù)。在加入keep-alive之前我使用路由和自定義組件的方式組織頁面的。
路由到詳情頁,然后詳情頁加載列表頁組件展現(xiàn),然后在組件模塊通過props:[‘id']獲取數(shù)據(jù)
import Vmothod from '../page/ApiMethodTable.vue'; import VsystemParam from '../page/ApiSystemParamTable.vue'; import VsystemError from '../page/ApiSystemErrorTable.vue'; <template> <div> <Vmothod :id="id"></Vmothod> <VsystemParam :id="id"></VsystemParam> <VsystemError :id="id"></VsystemError> </div> </template>
但是如此以來,在返回上一層或者修改數(shù)據(jù)回跳后,因?yàn)闆]有頁面緩存,所以頁數(shù)會變成第一頁,使用上很不方便。
在網(wǎng)上找了相關(guān)解決方案后,我試著在路由上加入了keep-alive參數(shù)。
meta: { keepAlive: true }
<keep-alive> <router-view v-if="$route.meta.keepAlive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepAlive"></router-view>
這樣解決了頁面不緩存的問題,但跳轉(zhuǎn)之后所有頁面都是一模一樣的數(shù)據(jù),這就很不對了。后臺發(fā)覺還要在頁面初始化時(shí)加入鉤子函數(shù)拉取數(shù)據(jù)
activated(){ this.getData(); }
但是發(fā)覺還是不行,上一頁通過props:[‘id']傳遞到組件參數(shù)也會被緩存,如此以來props不能用了,只有通過在路由來傳遞參數(shù)。
在路由的時(shí)候帶上id參數(shù)
path:'/method/:id'
然后在組件頁面獲取參數(shù)
self.$route.params.id
如此終于順暢的緩存了詳情頁的當(dāng)前頁面參數(shù)。
以上這篇vue2使用keep-alive緩存多層列表頁的方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue導(dǎo)入.md文件的步驟(markdown轉(zhuǎn)HTML)
這篇文章主要介紹了vue導(dǎo)入.md文件的步驟(markdown轉(zhuǎn)HTML),幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2020-12-12Vue中使用 setTimeout() setInterval()函數(shù)的問題
這篇文章主要介紹了Vue中使用 setTimeout() setInterval()函數(shù)的問題 ,需要的朋友可以參考下2018-09-09Vue組件傳值方式(props屬性,父到子,子到父,兄弟傳值)
這篇文章主要介紹了Vue組件傳值方式(props屬性,父到子,子到父,兄弟傳值),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06vue?watch監(jiān)聽觸發(fā)優(yōu)化搜索框的性能防抖節(jié)流的比較
這篇文章主要為大家介紹了vue?watch監(jiān)聽觸發(fā)優(yōu)化搜索框的性能防抖節(jié)流的比較,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-10-10