亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue里如何主動銷毀keep-alive緩存的組件

 更新時間:2019年03月21日 10:13:19   作者:old_bin  
這篇文章主要介紹了vue里如何主動銷毀keep-alive緩存的組件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

問題產(chǎn)生的背景

我們一個后臺,在切換一些標(biāo)簽頁的時候,是使用的 keep-alive 緩存的標(biāo)簽頁,也使用了 include 屬性來決定哪個頁面進(jìn)行緩存,而標(biāo)簽頁的切換實際上是路由的切換,也就是說打開一個新標(biāo)簽頁的時候,url 會跟著變化,老的標(biāo)簽頁如果在 keep-aliveinclude 范圍內(nèi)那就會緩存下來。

然后客服人員就反饋頁面開的久了就會崩潰,因為他們基礎(chǔ)上不會刷新頁面(工作需要),又總有切換標(biāo)簽的習(xí)慣,最后導(dǎo)致內(nèi)存越來越大最后崩潰。

依賴環(huán)境

這個項目是基于一個開源 vue 后臺框架:https://github.com/PanJiaChen/vue-element-admin,然后代碼一直由幾個后端開發(fā)維護(hù)的!所以后端沒找出問題在哪,然后就我來接手這個問題了。
寫文章時,標(biāo)簽里竟然沒有 vue 這一項,差評!

定位問題

先梳理下業(yè)務(wù)邏輯:從業(yè)務(wù)場景來說,我們在標(biāo)簽頁之間切換時,如果剛進(jìn)入的這個標(biāo)簽頁已被緩存了,那被緩存的標(biāo)簽頁就直接拿出來展示就行,而關(guān)閉這個標(biāo)簽頁的時候就應(yīng)該銷毀對應(yīng)的組件。

花了點時間查看了一下代碼,發(fā)現(xiàn)問題在于關(guān)閉標(biāo)簽頁的時候,雖然這個頁面沒在 keep-aliveinclude 里了,但是組件也沒有被銷毀掉,還是在緩存狀態(tài),我們可以通過 Vue Devtools 插件看到關(guān)閉后的標(biāo)簽頁對應(yīng)的組件一直還存在著:

當(dāng)然,在這塊 keep-alive 本身的邏輯我覺得是沒問題的,主要是我們項目比較復(fù)雜,緩存的組件太多了而且會一直增加,所以最終導(dǎo)致崩潰。

解決問題

既然問題已經(jīng)定位了,那就好解決問題了,只需要在關(guān)閉標(biāo)簽頁的時候把對應(yīng)的組件也銷毀掉就好了。

經(jīng)過網(wǎng)上一翻查找,發(fā)現(xiàn)銷毀一個組件可以使用: this.$destroy(‘組件名') 來銷毀。

先說下大概思路:keep-aliveinclude 里存的其實是一個 vuex 中的一個數(shù)據(jù)源(數(shù)據(jù)源保存的是路由名稱),當(dāng)關(guān)閉標(biāo)簽頁時,這個數(shù)據(jù)源中的一項會被移除。這之前,我們在組件里監(jiān)聽到這個數(shù)據(jù)源的變化,如果此組件對應(yīng)的路由(這個路由應(yīng)在 mounted 的時候保存下來)已經(jīng)不在數(shù)據(jù)源中了,那就應(yīng)該銷毀此組件。

代碼大概如下:

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)閉標(biāo)簽頁后對應(yīng)的組件就會被銷毀掉,使用 Vue Devtools 能看的很清楚。

更多思考

在我們后臺操作這么頻繁的業(yè)務(wù)場景下,使用 keep-alive 其實并不是一個好的選擇。

在我們修復(fù)這個問題后,我們通過控制臺里的 Memory 查看頁面內(nèi)存的變化時,發(fā)現(xiàn)組件即便被銷毀,也要經(jīng)過一段時間才能回收完,當(dāng)我們在這一段時間一直創(chuàng)建/打開新的標(biāo)簽頁時,內(nèi)存還是會在短時間內(nèi)高漲。而且有時候,內(nèi)存在經(jīng)過一段時間后也并沒有回收掉。

keep-alive 本質(zhì)上是把整個 dom 節(jié)點及對應(yīng)的事件等都緩存下來了,當(dāng)這樣的組件很多的時候,自然會占用很多內(nèi)存。而如果我們只緩存這個組件中的數(shù)據(jù),在需要這個組件再次顯示的時候再臨時渲染那肯定要節(jié)省很多內(nèi)存的,畢竟數(shù)據(jù)占的空間其實很小的,而渲染組件要花的時間也不會很長(只要組件不是特別特別復(fù)雜)。

所以,下一階段的優(yōu)化工作就是把 keep-alive 去掉,然后使用 vuex 來緩存組件中的數(shù)據(jù),當(dāng)需要重新顯示數(shù)據(jù)時再把數(shù)據(jù)取出來并重新渲染。當(dāng)然,這是一個比較大的工程!

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 從Vuex中取出數(shù)組賦值給新的數(shù)組,新數(shù)組push時報錯的解決方法

    從Vuex中取出數(shù)組賦值給新的數(shù)組,新數(shù)組push時報錯的解決方法

    今天小編就為大家分享一篇從Vuex中取出數(shù)組賦值給新的數(shù)組,新數(shù)組push時報錯的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • Vue+Node.js+WebSocket實現(xiàn)即時通訊

    Vue+Node.js+WebSocket實現(xiàn)即時通訊

    本文主要介紹了Vue+Node.js+WebSocket實現(xiàn)即時通訊,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Vue實現(xiàn)簡單的跑馬燈

    Vue實現(xiàn)簡單的跑馬燈

    這篇文章主要為大家詳細(xì)介紹了Vue實現(xiàn)簡單的跑馬燈,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • Vue3?入口文件createApp函數(shù)詳解

    Vue3?入口文件createApp函數(shù)詳解

    這篇文章主要介紹了Vue3?入口文件createApp函數(shù),本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • vuex之this.$store.dispatch()與this.$store.commit()的區(qū)別及說明

    vuex之this.$store.dispatch()與this.$store.commit()的區(qū)別及說明

    這篇文章主要介紹了vuex之this.$store.dispatch()與this.$store.commit()的區(qū)別及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Vue組件之事件總線和消息發(fā)布訂閱詳解

    Vue組件之事件總線和消息發(fā)布訂閱詳解

    這篇文章主要為大家詳細(xì)介紹了Vue組件之事件總線和消息發(fā)布訂閱,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • Vue 關(guān)閉當(dāng)前頁、關(guān)閉當(dāng)前標(biāo)簽tagsView的實現(xiàn)方法

    Vue 關(guān)閉當(dāng)前頁、關(guān)閉當(dāng)前標(biāo)簽tagsView的實現(xiàn)方法

    這篇文章主要介紹了Vue 關(guān)閉當(dāng)前頁、關(guān)閉當(dāng)前標(biāo)簽tagsView,主要有兩種方式,一種是在vue頁面直接實現(xiàn),另一種在js文件中寫自定義函數(shù),在vue頁面中調(diào)用,本文通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08
  • 基于Vue框架vux組件庫實現(xiàn)上拉刷新功能

    基于Vue框架vux組件庫實現(xiàn)上拉刷新功能

    這篇文章主要為大家詳細(xì)介紹了基于Vue框架vux組件庫實現(xiàn)上拉刷新功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • 解決VUE項目在IIS部署出現(xiàn):Uncaught SyntaxError: Unexpected token < 報錯

    解決VUE項目在IIS部署出現(xiàn):Uncaught SyntaxError: Unexpected&n

    這篇文章介紹了解決VUE項目在IIS部署出現(xiàn):Uncaught SyntaxError: Unexpected token < 報錯的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-04-04
  • Vue3基于?rem?比例縮放方案示例詳解

    Vue3基于?rem?比例縮放方案示例詳解

    這篇文章主要介紹了Vue3基于rem比例縮放方案,本縮放方案置于hooks中即可,文中通過示例代碼介紹了vue-cli3 中使用rem布局的方法,需要的朋友可以參考下
    2023-05-05

最新評論