vue使用keep-alive實(shí)現(xiàn)數(shù)據(jù)緩存不刷新

到現(xiàn)在,接觸vue也小段時(shí)間了,項(xiàng)目進(jìn)行到了一定程度,然而項(xiàng)目缺少了緩存機(jī)制,所以每次跳轉(zhuǎn)頁面都會(huì)重新created一下數(shù)據(jù),雖說系統(tǒng)的數(shù)據(jù)請(qǐng)求速度很快,但是這樣做對(duì)系統(tǒng)的性能會(huì)有很大的壞處的,所以到這里就要對(duì)系統(tǒng)優(yōu)化下,添加緩存了。

其實(shí)到現(xiàn)在,對(duì)于vue還是沒有玩通,每深挖一次,就會(huì)發(fā)現(xiàn)一次vue的精彩,開始不清楚要用什么實(shí)現(xiàn)緩存,找了好久,有好幾種說法,就是用vuex、vuet或者keep-alive,然后對(duì)比了一下,在我認(rèn)為,vuex和vuet是實(shí)現(xiàn)狀態(tài)管理,重心是在數(shù)據(jù)處理上;想要實(shí)現(xiàn)整體的緩存,阻止created的刷新,就要用keep-alive。

所以這里我想要給大家介紹下如何用keep-alive實(shí)現(xiàn)緩存的頁面?其實(shí)很簡單,就是幾句話而已。

1、keep-alive要配合router-view使用,這里要注意一點(diǎn)就是,keep-alive本身是vue2.0的功能,并不是vue-router的,所以再vue1.0版本是不支持的。keep-alive官方文檔點(diǎn)這里,代碼實(shí)現(xiàn)如下,router-view是在入口APP.vue里面

2、這樣就會(huì)實(shí)現(xiàn)組件的緩存,但是有個(gè)缺點(diǎn)就是所有組件都會(huì)被緩存,可是現(xiàn)實(shí)中就是我們有些頁面還是要及時(shí)刷新的,比如列表數(shù)據(jù),想要查看詳情的時(shí)候都是共用一個(gè)組件,只是刷新頁面,所以這個(gè)共用的組件是不能夠緩存的,不然會(huì)造成點(diǎn)其他的條目都是之前緩存的數(shù)據(jù)。那要怎么自定義呢,那就要在router-view里面多加個(gè)v-if判斷了,然后在router定義的文件里面在想要緩存的頁面多加上“meta:{keepAlive:true}”,不想要緩存就是“meta:{keepAlive:false}”或者不寫,只有為true的時(shí)候是會(huì)被keep-alive識(shí)別然后緩存的。

3、在router文件加上meta判斷

importVuefrom'vue'importRouterfrom'vue-router'Vue.use(Router)exportdefaultnewRouter({? ? {//home會(huì)被緩存path:"/home",component:home,meta:{keepAlive:true}? ? }? ? {//hello不會(huì)被緩存path:"/hello",component:hello,meta:{keepAlive:false}? ? }})

想要看有沒有緩存成功,可以在各個(gè)組件的created鉤子里面打印輸出標(biāo)志,緩存成功就是首次進(jìn)入頁面,created會(huì)請(qǐng)求數(shù)據(jù),后面就不會(huì)再次請(qǐng)求而是直接調(diào)用緩存的

添加了緩存可以大大減少對(duì)系統(tǒng)性能的損壞,畢竟做數(shù)據(jù)處理型的系統(tǒng),數(shù)據(jù)過于龐大,每次都要請(qǐng)求一下頁面是很不好的,有了緩存,該緩存的緩存,不想緩存也可以實(shí)時(shí)刷新

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. 背景 vue 中有一個(gè) keep-alive 的功能,可以將組件渲染結(jié)果緩存起來,結(jié)合 vue-router...
    書SHU閱讀 6,851評(píng)論 2 10
  • keep-alive keep-alive是Vue提供的一個(gè)抽象組件,用來對(duì)組件進(jìn)行緩存,從而節(jié)省性能,由于是一個(gè)...
    羊烊羴閱讀 232,941評(píng)論 7 103
  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容。關(guān)于...
    云之外閱讀 5,180評(píng)論 0 29
  • 是Vue的內(nèi)置組件,能在組件切換過程中將狀態(tài)保留在內(nèi)存中,防止重復(fù)渲染DOM。 包裹動(dòng)態(tài)組件時(shí),會(huì)緩存不活動(dòng)的組件...
    為君梳作半面妝閱讀 1,582評(píng)論 0 2
  • 以前對(duì)于房子一直抱著無所謂的態(tài)度,今年9月這次租房風(fēng)波之后,感覺真的要買一處了,房子在哪不一定家在什么地方,但起碼...
    沙河幾中閱讀 321評(píng)論 0 0

友情鏈接更多精彩內(nèi)容