這篇文章給大家分享的是有關(guān)vue里主動銷毀keep-alive緩存的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
創(chuàng)新互聯(lián)建站主要從事成都網(wǎng)站制作、成都網(wǎng)站設計、網(wǎng)頁設計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務。立足成都服務陽江,10年網(wǎng)站建設經(jīng)驗,價格優(yōu)惠、服務專業(yè),歡迎來電咨詢建站服務:028-86922220
問題產(chǎn)生的背景
我們一個后臺,在切換一些標簽頁的時候,是使用的 keep-alive
緩存的標簽頁,也使用了 include
屬性來決定哪個頁面進行緩存,而標簽頁的切換實際上是路由的切換,也就是說打開一個新標簽頁的時候,url 會跟著變化,老的標簽頁如果在 keep-alive
的 include
范圍內(nèi)那就會緩存下來。
然后客服人員就反饋頁面開的久了就會崩潰,因為他們基礎(chǔ)上不會刷新頁面(工作需要),又總有切換標簽的習慣,最后導致內(nèi)存越來越大最后崩潰。
依賴環(huán)境
這個項目是基于一個開源 vue
后臺框架:https://github.com/PanJiaChen/vue-element-admin
,然后代碼一直由幾個后端開發(fā)維護的!所以后端沒找出問題在哪,然后就我來接手這個問題了。
寫文章時,標簽里竟然沒有 vue
這一項,差評!
定位問題
先梳理下業(yè)務邏輯:從業(yè)務場景來說,我們在標簽頁之間切換時,如果剛進入的這個標簽頁已被緩存了,那被緩存的標簽頁就直接拿出來展示就行,而關(guān)閉這個標簽頁的時候就應該銷毀對應的組件。
花了點時間查看了一下代碼,發(fā)現(xiàn)問題在于關(guān)閉標簽頁的時候,雖然這個頁面沒在 keep-alive
的 include
里了,但是組件也沒有被銷毀掉,還是在緩存狀態(tài),我們可以通過 Vue Devtools
插件看到關(guān)閉后的標簽頁對應的組件一直還存在著:
當然,在這塊 keep-alive
本身的邏輯我覺得是沒問題的,主要是我們項目比較復雜,緩存的組件太多了而且會一直增加,所以最終導致崩潰。
解決問題
既然問題已經(jīng)定位了,那就好解決問題了,只需要在關(guān)閉標簽頁的時候把對應的組件也銷毀掉就好了。
經(jīng)過網(wǎng)上一翻查找,發(fā)現(xiàn)銷毀一個組件可以使用: this.$destroy(‘組件名')
來銷毀。
先說下大概思路:keep-alive
的 include
里存的其實是一個 vuex
中的一個數(shù)據(jù)源(數(shù)據(jù)源保存的是路由名稱),當關(guān)閉標簽頁時,這個數(shù)據(jù)源中的一項會被移除。這之前,我們在組件里監(jiān)聽到這個數(shù)據(jù)源的變化,如果此組件對應的路由(這個路由應在 mounted
的時候保存下來)已經(jīng)不在數(shù)據(jù)源中了,那就應該銷毀此組件。
代碼大概如下:
const mixin = { data() { return { routePath: '' } }, mounted() { this.routePath = this.$route.path }, computed: { visitedViews() { return this.$store.state.tagsView.visitedViews } }, watch: { visitedViews(value) { if(value 里沒有了 routePath 這一項) this.$destroy(this.$options.name) } } } } export default mixin
這一段代碼單獨拎出來了,然后在需要緩存的組件里使用 mixins
混入到組件對象中,這樣組件中要添加的代碼量就比較少了。
更改后經(jīng)過測試,關(guān)閉標簽頁后對應的組件就會被銷毀掉,使用 Vue Devtools
能看的很清楚。
更多思考
在我們后臺操作這么頻繁的業(yè)務場景下,使用 keep-alive
其實并不是一個好的選擇。
在我們修復這個問題后,我們通過控制臺里的 Memory
查看頁面內(nèi)存的變化時,發(fā)現(xiàn)組件即便被銷毀,也要經(jīng)過一段時間才能回收完,當我們在這一段時間一直創(chuàng)建/打開新的標簽頁時,內(nèi)存還是會在短時間內(nèi)高漲。而且有時候,內(nèi)存在經(jīng)過一段時間后也并沒有回收掉。
keep-alive
本質(zhì)上是把整個 dom
節(jié)點及對應的事件等都緩存下來了,當這樣的組件很多的時候,自然會占用很多內(nèi)存。而如果我們只緩存這個組件中的數(shù)據(jù),在需要這個組件再次顯示的時候再臨時渲染那肯定要節(jié)省很多內(nèi)存的,畢竟數(shù)據(jù)占的空間其實很小的,而渲染組件要花的時間也不會很長(只要組件不是特別特別復雜)。
所以,下一階段的優(yōu)化工作就是把 keep-alive
去掉,然后使用 vuex
來緩存組件中的數(shù)據(jù),當需要重新顯示數(shù)據(jù)時再把數(shù)據(jù)取出來并重新渲染。當然,這是一個比較大的工程!
感謝各位的閱讀!關(guān)于“vue里主動銷毀keep-alive緩存”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
標題名稱:vue里主動銷毀keep-alive緩存
本文URL:http://aaarwkj.com/article10/gpjodo.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站制作、微信公眾號、品牌網(wǎng)站制作、網(wǎng)站策劃、企業(yè)建站、服務器托管
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)