elementui實現(xiàn)標(biāo)簽頁與菜單欄聯(lián)動的示例代碼
技術(shù):vue2+vuex+elementui

store/index.js文件里
import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex)
export default new Vuex.Store({
state: {
tabList:[]
},
mutations: {
addTab: (state, tab) => {
// 如果tab已經(jīng)存在,不添加新的tabs
if (state.tabList.some(item => item.path === tab.path)) return
state.tabList.push(tab)
}
},
getters: {
// 獲取tbsList
getTabs: (state) => {
return state.tabList
}
},
actions: {
},
modules: {
}
})
功能點:
1:當(dāng)前活躍的tab就是當(dāng)前路由的path
2: 頁面刷新,tabList數(shù)據(jù)丟失,則在刷新之前使用sessionStorage進行存儲
3:刪除tab的時候,活躍的tab變?yōu)楸粍h除的前一個或者下一個,刪除后重新設(shè)置活躍的tab 和tabList
4:監(jiān)控路由變化,路由變化了,活躍的tab 和tabList 也要隨之變化
<template>
<el-tabs
v-model="activeTab"
closable
@tab-remove="removeTab"
@tab-click="clickBtn"
>
<el-tab-pane
:key="index"
v-for="(item, index) in tabList"
:label="item.title"
:name="item.path"
>
{{ item.content }}
</el-tab-pane>
</el-tabs>
</template>
<script>
import store from '../../store'
export default {
name: '',
data() {
return {
// 當(dāng)前活躍的tabs
activeTab: '',
}
},
components: {},
computed: {
tabList() {
return store.getters['getTabs']
},
},
watch: {
$route: function () {
this.setActiveTab()
this.addTab()
},
},
created() {},
mounted() {
this.beforeRefresh()
this.setActiveTab()
this.addTab()
},
methods: {
// 設(shè)置活躍的tab
setActiveTab() {
this.activeTab = this.$route.path
},
// 添加tab
addTab() {
const { path, meta } = this.$route
const tab = {
path,
title: meta.title,
}
store.commit('addTab', tab)
},
// 點擊tab
clickBtn(tab) {
const { name } = tab
this.$router.push({ path: name })
},
// 刪除tab
removeTab(target) {
// 當(dāng)前激活的tab
let active = this.activeTab
const tabs = this.tabList
// 只有一個標(biāo)簽頁的時候不允許刪除
if (tabs.length === 1) return
if (active === target) {
tabs.forEach((tab, index) => {
// 如果刪除的就是當(dāng)前活躍的tab,就把活躍的tab變成上一個或下一個
const nextTab = tab[index + 1] || tab[index - 1]
if (nextTab) {
active = nextTab.path
}
})
}
// 重新設(shè)置當(dāng)前激活的選項卡和 選項卡列表
this.activeTab = active
store.state.tabList = tabs.filter((tab) => tab.path !== target)
},
// 解決刷新數(shù)據(jù)丟失問題
beforeRefresh() {
window.addEventListener('beforeunload', () => {
sessionStorage.setItem('tabsView', JSON.stringify(this.tabList))
})
let tabSession = sessionStorage.getItem('tabsView')
if (tabSession) {
let oldTabs = JSON.parse(tabSession)
if (oldTabs.length > 0) {
store.state.tabList = oldTabs
}
}
},
},
}
</script>
補充:路由
{
path: '/layout',
component: () => import('../layout/index.vue'),
children: [
{
path: 'lay1',
component: () => import('../views/lay/Lay1.vue'),
meta: {
title:'選項1'
}
},
{
path: 'lay2',
component: () => import('../views/lay/Lay2.vue'),
meta: {
title:'選項2'
}
},
{
path: 'lay3',
component: () => import('../views/lay/Lay3.vue'),
meta: {
title:'選項3'
}
},
{
path: 'lay4',
component: () => import('../views/lay/Lay4.vue'),
meta: {
title:'選項4'
}
},
}到此這篇關(guān)于elementui實現(xiàn)標(biāo)簽頁與菜單欄聯(lián)動的示例代碼的文章就介紹到這了,更多相關(guān)element 標(biāo)簽頁與菜單欄聯(lián)動內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- 詳解Vue、element-ui、axios實現(xiàn)省市區(qū)三級聯(lián)動
- vue elementUI使用tabs與導(dǎo)航欄聯(lián)動
- 詳解element-ui級聯(lián)菜單(城市三級聯(lián)動菜單)和回顯問題
- vue + elementUI實現(xiàn)省市縣三級聯(lián)動的方法示例
- element實現(xiàn)二級菜單和頂部導(dǎo)航聯(lián)動的示例
- vue基于element-china-area-data插件實現(xiàn)省市區(qū)聯(lián)動
- 利用vue+elementUI設(shè)置省市縣三級聯(lián)動下拉列表框的詳細過程
- ElementUI中兩個Select選擇聯(lián)動效果實現(xiàn)方法
相關(guān)文章
vue項目持久化存儲數(shù)據(jù)的實現(xiàn)代碼
這篇文章主要介紹了vue項目持久化存儲數(shù)據(jù)的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-10-10
vue3動態(tài)路由刷新出現(xiàn)空白頁的原因與最優(yōu)解
頁面刷新白屏其實是因為vuex引起的,由于刷新頁面vuex數(shù)據(jù)會丟失,這篇文章主要給大家介紹了關(guān)于vue3動態(tài)路由刷新出現(xiàn)空白頁的原因與最優(yōu)解的相關(guān)資料,需要的朋友可以參考下2023-11-11

