溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在vue中利用keep-alive實現(xiàn)數(shù)據(jù)緩存不刷新

發(fā)布時間:2021-03-30 16:04:41 來源:億速云 閱讀:157 作者:Leah 欄目:web開發(fā)

這篇文章給大家介紹怎么在vue中利用keep-alive實現(xiàn)數(shù)據(jù)緩存不刷新,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

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

<template>
 <div id="app">

  <keep-alive>
   <router-view></router-view>
  </keep-alive>
  
  <!--這里是其他的代碼-->
 </div>
</template>

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

<template>
 <div id="app">
  <!--緩存想要緩存的頁面,實現(xiàn)后退不刷新-->
  <!--加上v-if的判斷,可以自定義想要緩存的組件,自定義在router里面-->
  <keep-alive>
   <router-view v-if="$route.meta.keepAlive"></router-view>
  </keep-alive>
  <router-view v-if="!$route.meta.keepAlive"></router-view>
  
  <!--這里是其他的代碼-->
 </div>
</template>

3、在router文件加上meta判斷

import Vue from 'vue'
import Router from 'vue-router'

Vue.use(Router)
export default new Router({
  {//home會被緩存
    path:"/home",
    component:home,
    meta:{keepAlive: true}
  }
  {//hello不會被緩存
    path:"/hello",
    component:hello,
    meta:{keepAlive: false}
  }
})

關于怎么在vue中利用keep-alive實現(xiàn)數(shù)據(jù)緩存不刷新就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI