解決vue單頁使用keep-alive頁面返回不刷新的問題
使用vue單頁開發(fā)項(xiàng)目時(shí)遇到一個(gè)很惡心的問題:在列表頁點(diǎn)擊一條數(shù)據(jù)進(jìn)入詳情頁,按返回鍵返回列表頁時(shí)頁面刷新了,用戶體驗(yàn)非常差啊?。?!查閱了一下相關(guān)問題,使用<keep-alive>解決這個(gè)問題,下面是我的使用心得。
<keep-alive>是Vue的內(nèi)置組件,能在組件切換過程中將狀態(tài)保留在內(nèi)存中,防止重復(fù)渲染DOM。
首先在App.vue頁面上有下面一段代碼,我們都知道這是頁面渲染的地方
<router-view></router-view>
把這段代碼改成如下:
<keep-alive> <router-view v-if="$route.meta.keepAlive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepAlive"></router-view>
我們能看到這段代碼做的邏輯判斷,當(dāng)路由的meta屬性的keepAlive屬性值為true時(shí)頁面的狀態(tài)保存,其他情況下不保存狀態(tài)。
然后就是給我們路由設(shè)置keepAlive屬性值,比如我是給主頁(列表頁)的路由設(shè)置了keepAlive屬性為true。
{
name: 'index',
path: '/index',
title: '主頁',
component(resolve) {
require(['views/index.vue'], resolve)
},
meta: {
pageTitle: '主頁',
keepAlive: true
}
}
這樣設(shè)置了之后,主頁的狀態(tài)就會(huì)保存,返回鍵返回到主頁時(shí)頁面不會(huì)刷新請(qǐng)求數(shù)據(jù)了。
但是有問題?。。?!從主頁跳到任何頁面,再返回主頁都不會(huì)刷新頁面!這并不是我想要的,我只要從詳情頁返回列表頁時(shí)不刷新頁面,其他情況下是需要刷新的,那么我就需要定制化處理了。大致思路就是從主頁跳轉(zhuǎn)到其他頁面時(shí)把主頁的keepAlive值設(shè)置為false,從詳情頁返回主頁時(shí)把主頁的keepAlive值設(shè)置為true就好了,代碼如下:
主頁跳轉(zhuǎn)到其他頁面時(shí)把主頁的keepAlive值設(shè)置為false
export default {
data() {
return {
};
},
mounted() {
},
methods: {
},
//修改列表頁的meta值,false時(shí)再次進(jìn)入頁面會(huì)重新請(qǐng)求數(shù)據(jù)。
beforeRouteLeave(to, from, next) {
from.meta.keepAlive = false;
next();
}
};
從詳情頁返回主頁時(shí)把主頁的keepAlive值設(shè)置為true(要做個(gè)判斷,判斷是不是返回到主頁的)
export default {
data() {
return {
};
},
mounted() {
},
methods: {
},
beforeRouteLeave(to, from, next) {
if (to.path == "/index") {
to.meta.keepAlive = true;
} else {
to.meta.keepAlive = false;
}
next();
}
};
這里使用了beforeRouterLeave(to,from,next){},它是methods平級(jí)的,具體使用方法可以查閱一下。
注意問題:
beforeRouterLeave必須寫在有配置路由的頁面上才有效的,最開始我想寫在App.vue頁面上,發(fā)現(xiàn)根本就不執(zhí)行的!
以上這篇解決vue單頁使用keep-alive頁面返回不刷新的問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue-element-admin搭建后臺(tái)管理系統(tǒng)的實(shí)現(xiàn)步驟
本文主要介紹了vue-element-admin搭建后臺(tái)管理系統(tǒng)的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-10-10
vue路由切換之淡入淡出的簡(jiǎn)單實(shí)現(xiàn)
今天小編就為大家分享一篇vue路由切換之淡入淡出的簡(jiǎn)單實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-10-10
vue-admin-box第一步npm?install時(shí)報(bào)錯(cuò)的處理
這篇文章主要介紹了vue-admin-box第一步npm?install時(shí)報(bào)錯(cuò)的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
基于electron+vue3+ts搭建桌面端應(yīng)用并且可以熱更新
這篇文章主要為大家詳細(xì)介紹了如何基于electron+vue3+ts搭建桌面端應(yīng)用并且可以熱更新,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以參考下2023-10-10
vuex實(shí)現(xiàn)及簡(jiǎn)略解析(小結(jié))
這篇文章主要介紹了vuex實(shí)現(xiàn)及簡(jiǎn)略解析(小結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03
使用vue-cli搭建SPA項(xiàng)目的詳細(xì)過程
vue-cli是vue.js的腳手架,用于自動(dòng)生成vue.js+webpack的項(xiàng)目模板,本文通過實(shí)例代碼給大家介紹vue-cli搭建SPA項(xiàng)目的詳細(xì)過程,感興趣的朋友跟隨小編一起看看吧2022-09-09
Vue項(xiàng)目線上更新無需強(qiáng)制刷新的幾種實(shí)現(xiàn)方案(無感更新)
在 Vue 項(xiàng)目中,當(dāng)發(fā)布新版本后,用戶可能因?yàn)闉g覽器緩存而繼續(xù)使用舊版本,所以本文給大家介紹了Vue 項(xiàng)目線上更新無需強(qiáng)制刷新的幾種實(shí)現(xiàn)方案,并通過代碼示例講解的非常詳細(xì),需要的朋友可以參考下2025-03-03
axios請(qǐng)求二次封裝之避免重復(fù)發(fā)送請(qǐng)求
在做vue中大型項(xiàng)目的時(shí)候,官方推薦使用axios,但是原生的axios可能對(duì)項(xiàng)目的適配不友好,所以在工程開始的來封裝一下axios,下面這篇文章主要給大家介紹了關(guān)于axios請(qǐng)求二次封裝之避免重復(fù)發(fā)送請(qǐng)求的相關(guān)資料,需要的朋友可以參考下2022-10-10

