您好,登錄后才能下訂單哦!
本篇內容介紹了“Vue中的keep-alive如何使用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
keep-alive 是 Vue 的內置組件,當它包裹動態組件時,會緩存不活動的組件實例,而不是銷毀它們。例如:在開發中經常有從列表跳到詳情頁,然后返回詳情頁的時候需要緩存列表頁的狀態(比如滾動位置信息),這個時候就需要保存狀態,要緩存狀態。在組件切換過程中將狀態保留在內存中,防止重復渲染DOM,減少加載時間及性能消耗,提高用戶體驗性。使用方式為
<keep-alive> <component /> </keep-alive>
這里的component會被緩存。
keep-alive是Vue的內置組件,當它包裹動態組件時,會緩存不活動的組件實例,而不是銷毀。
用來緩存組件,避免多次加載相同的組件,減少性能消耗,提高用戶體驗。
方式一:在App.vue中使用keep-alive標簽,表示緩存所有頁面
<div id="app"> <keep-alive> <tar-bar></tar-bar> <div class="container"> <left-menu></left-menu> <Main /> </div> </keep-alive> </div>
方式二:按條件緩存,使用include,exclude判斷是否緩存
// 1. 將緩存 name 為 cc 的組件,如果有多個,可用逗號分 <keep-alive include='cc'> <router-view/> </keep-alive> // 2. 將不緩存 name 為 cc 的組件 <keep-alive exclude='cc'> <router-view/> </keep-alive> // 3. 還可使用屬性綁定動態判斷 <keep-alive :include='includedComs'> <router-view/> </keep-alive>
方式三:在router目錄下的index.js中,
第一步:使用meta:{keepAlive = true },表示需要緩存
const routes = [ { path:'/', component:Home, meta:{ keepalive:true } }, { path:'/login', component:Login }, { path:'/edit', component:Edit, meta:{ istoken: true } }, { path:'/home', component:Home, meta:{ keepalive:true } } ]
第二步:在App.vue中進行判斷
<div id="app"> <!--keep-alive 表示頁面不會被銷毀,即保持頁面狀態--> <keep-alive> <router-view v-if="$route.meta.keepalive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepalive"></router-view> </div>
“Vue中的keep-alive如何使用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。