vue Tab切換以及緩存頁面處理的幾種方式
1.如何切換
使用動態(tài)組件,相信大家都能看懂(部分代碼省略)
//通過點擊就可以實現(xiàn)兩個組件來回切換 <button @click="changeView">切換view</button> <component :is="currentView"></component> import pageA from "@/views/pageA"; import pageB from "@/views/pageB"; computed: { currentView(){ return this.viewList[this.index]; } }, methods: { changeView() { this.index=(++this.index)%2 } }
注:這個多用于單頁下的幾個子模塊使用,一般切換比較多使用下面的路由
使用路由(這個就是配置路由的問題了,不作贅述)
2.動態(tài)生成tab
一般UI框架給我們的tab切換都像是上面的那種,需要自己寫入幾個tab頁之類的配置。但是我們?nèi)绻胍ㄟ^點擊左邊的目錄來生成一個tab頁并且可以隨時關(guān)閉呢(如下圖)?
只需要給路由一個點擊事件,把你的路由地址保存到一個列表,渲染成另一個平鋪的tab目錄即可
假設(shè)你的布局是這樣,左邊的目錄,上邊的tab,有字的是頁面
<menu> <menu-item v-for="(item,index) in menuList" :key="index" @click="addToTabList(item.path)"> <router-link :to="item.path">{{item.name}}</router-link> <menu-item> </menu>
<template> <menu class="left"/>//menu代碼部分如上 <div class="right"> <tab-list> <tab-item v-for="(item,index) in tabList" :key="index"> <router-link :to="item.path">{{item.name}}</router-link> <icon class="delete" @click="deleteTab"></icon> </tab-item> </tab-list> <page-view> <router-view></router-view>//這里是頁面展示 </page-view> </div> </template>
以上代碼并非實際代碼,只提供一個大概的思路。至于addToTabList和deleteTab怎么做就是數(shù)組方法的簡單push和splice操作了。為了效果好看,我們可能還需要一些tab的active樣式,這里不作演示。
3.緩存組件
僅僅是做tab切換,遠(yuǎn)遠(yuǎn)是不夠的,畢竟大家想要tab頁就是要來回切換操作,我們需要保存他在不同tab里操作的進(jìn)度,比如說填寫的表單信息,或者已經(jīng)查詢好的數(shù)據(jù)列表等。
那么我們要怎么緩存組件呢?
只需要用到vue中的keep-alive組件
3.1 keep-alive
- <keep-alive>是Vue的內(nèi)置組件,能在組件切換過程中將狀態(tài)保留在內(nèi)存中,防止重復(fù)渲染DOM。
- <keep-alive> 包裹動態(tài)組件時,會緩存不活動的組件實例,而不是銷毀它們。
- <keep-alive> 與 <transition>相似,只是一個抽象組件,它不會在DOM樹中渲染(真實或者虛擬都不會),也不在父組件鏈中存在,比如:你永遠(yuǎn)在 this.$parent 中找不到 keep-alive 。
注:不能使用keep-alive來緩存固定組件,會無效
//無效 <keep-alive> <my-component></my-component> </keep-alive>
3.2 使用
3.2.1 老版本vue 2.1之前的使用
<keep-alive> <router-view v-if="$route.meta.keepAlive"></router-view> </keep-alive> <router-view v-if="!$route.meta.keepAlive"></router-view>
需要在路由信息里面設(shè)置router的元信息meta
export default new Router({ routes: [ { path: '/a', name: 'A', component: A, meta: { keepAlive: false // 不需要緩存 } }, { path: '/b', name: 'B', component: B, meta: { keepAlive: true // 需要被緩存 } } ] })
3.2.2 比較新而且簡單的用法
直接緩存所有組件/路由
<keep-alive> <router-view/> </keep-alive> <keep-alive> <component :is="view"></component> </keep-alive>
使用include來處理需要緩存的組件/路由
include有幾種用法,可以是數(shù)組,字符串用標(biāo)點隔開,也可以是正則,使用正則的時候需要使用v-bind來綁定。
<keep-alive include="['a','b']">//緩存name為a,b的組件 <keep-alive include ="a,b">//緩存name為a,b的組件 <keep-alive :include="/^store/">//緩存name以store開頭的組件 <router-view/>//可以為router-view <component :is="view"></component>//也可以是動態(tài)組件 </keep-alive>
使用exclude來排除不需要緩存的路由
跟include正好相反,在exclude里的組件不會被緩存。用法類似,不作贅述
3.2.3 一種比較奇怪的情況
當(dāng)頁面跳轉(zhuǎn)方式有A->C和B->C兩種,但是我們從A到C的時候,不需要緩存,從B到C的時候需要緩存。這時候就要用到路由的鉤子結(jié)合老版本用法來實現(xiàn)了。
export default { data() { return {}; }, methods: {}, beforeRouteLeave(to, from, next) { to.meta.keepAlive = false; // 讓下一頁不緩存 next(); } };
export default { data() { return {}; }, methods: {}, beforeRouteLeave(to, from, next) { // 設(shè)置下一個路由的 meta to.meta.keepAlive = true; //下一頁緩存 next(); } };
3.3 緩存組件的生命周期函數(shù)
緩存組件第一次打開的時候,和普通組件一樣,也需要執(zhí)行created, mounted等函數(shù)。
但是在被再次激活和被停用時,這幾個普通組件的生命周期函數(shù)都不會執(zhí)行,會執(zhí)行兩個比較獨特的生命周期函數(shù)。
- activated
這個會在緩存的組件重新激活時調(diào)用
- deactivated
這個會在緩存的組件停用時調(diào)用
以上就是vue Tab切換以及緩存頁面處理的幾種方式的詳細(xì)內(nèi)容,更多關(guān)于vue Tab切換以及緩存頁面處理的資料請關(guān)注腳本之家其它相關(guān)文章!
- vue Tab切換以及緩存頁面處理的幾種方式
- vue實現(xiàn)tab切換的3種方式及切換保持?jǐn)?shù)據(jù)狀態(tài)
- vue使用動態(tài)組件實現(xiàn)TAB切換效果
- vue組件開發(fā)之tab切換組件使用詳解
- Vue解決echart在element的tab切換時顯示不正確問題
- vue tab滾動到一定高度,固定在頂部,點擊tab切換不同的內(nèi)容操作
- vue 實現(xiàn)tab切換保持?jǐn)?shù)據(jù)狀態(tài)
- vue tab切換,解決echartst圖表寬度只有100px的問題
- vue vantUI tab切換時 list組件不觸發(fā)load事件的問題及解決方法
相關(guān)文章
Vue中"This dependency was not found"問題的解決方法
這篇文章主要介紹了Vue中"This dependency was not found"的問題的解決方法,需要的朋友可以參考下2018-06-06Vue無法訪問.env.development定義的變量值問題及解決
這篇文章主要介紹了Vue無法訪問.env.development定義的變量值問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01