elementui中使用el-tabs切換實時更新數(shù)據(jù)
使用el-tabs切換實時更新數(shù)據(jù)
項目中使用el-tabs 發(fā)現(xiàn)會一次性把所有 tab 里的請求讀完,之后進(jìn)行 tab 切換,不再重新讀取請求
想要實現(xiàn)切換 tab 能實時更新數(shù)據(jù)的要求
<el-tabs type="border-card" class="root" v-model="activeName" @tab-click="handleTabClick"> ? ?<el-tab-pane label="menu" name="menu"> ? ? ?<menu-perm :menus="menus" v-if="tabRefresh.menu" /> ? ?</el-tab-pane> ? ?<el-tab-pane label="perm" name="perm"> ? ? ?<api-perm :permissions="permissions" v-if="tabRefresh.perm" /> ? ?</el-tab-pane> ? ?<el-tab-pane label="data" name="data"> ? ? ?<span v-if="tabRefresh.data">數(shù)據(jù)授權(quán)</span> ? ?</el-tab-pane> ?</el-tabs>
js 部分
export default {
? data () {
? ? return {
? ? ? activeName: 'menu',
? ? ? tabRefresh: {
? ? ? ? menu: true,
? ? ? ? perm: false,
? ? ? ? data: false
? ? ? }
? ? }
? },
? methods: {
? ? handleTabClick (tab) {
? ? ? this.activeName = tab.name
? ? ? switch (this.activeName) {
? ? ? ? case 'menu':
? ? ? ? ? this.switchTab('menu')
? ? ? ? ? break
? ? ? ? case 'perm':
? ? ? ? ? this.switchTab('perm')
? ? ? ? ? break
? ? ? ? case 'data':
? ? ? ? ? this.switchTab('data')
? ? ? ? ? break
? ? ? }
? ? },
? ? switchTab (tab) {
? ? ? for (let key in this.tabRefresh) {
? ? ? ? if (key === tab) {
? ? ? ? ? this.tabRefresh[key] = true
? ? ? ? } else {
? ? ? ? ? this.tabRefresh[key] = false
? ? ? ? }
? ? ? }
? ? },
? }
}通過 v-if 進(jìn)行選擇性渲染,切換 tab 后,將其重新激活,并重新請求后端數(shù)據(jù)
el-tabs切換確認(rèn)
實現(xiàn)效果

相關(guān)知識
el-tabs具有屬性before-leave

解決代碼
<template>
<el-tabs v-model="activeName" :before-leave="leaveTab">
<el-tab-pane label="用戶管理" name="first">用戶管理</el-tab-pane>
<el-tab-pane label="配置管理" name="second">配置管理</el-tab-pane>
<el-tab-pane label="角色管理" name="third">角色管理</el-tab-pane>
<el-tab-pane label="定時任務(wù)補(bǔ)償" name="fourth">定時任務(wù)補(bǔ)償</el-tab-pane>
</el-tabs>
</template>
<script>
data(){
return{
activeName:"first"
}
}
methods:{
leaveTab(){
let a = confirm('有未保存的更改, 確認(rèn)離開?')
if (a) {
console.log('確認(rèn)')
return true
} else {
console.log('取消')
return false
}
}
}
</script>
解釋
:before-leave是屬性,需要綁定一個值。這個值是通過leaveTab傳遞的
這個問題很簡單……但是困擾了有幾天……要多看看 官方文檔?。。?!
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue實現(xiàn)長圖垂直居上 vue實現(xiàn)短圖垂直居中
這篇文章主要為大家詳細(xì)介紹了vue彈性布局實現(xiàn)長圖垂直居上,vue實現(xiàn)短圖垂直居中,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10
在Vue3項目中使用Vuex進(jìn)行狀態(tài)管理的詳細(xì)教程
在?Vue?3?中使用?Vuex?進(jìn)行狀態(tài)管理是一個很好的實踐,特別是在涉及到多個組件間共享狀態(tài)的情況,下面是如何在?Vue?3?項目中設(shè)置和使用?Vuex?的教程,包括?state,?mutations,?actions,?getters?的概念及其用途,需要的朋友可以參考下2024-09-09
基于vue+elementPlus的動態(tài)導(dǎo)航標(biāo)簽欄tabs具體過程
這篇文章主要給大家介紹了關(guān)于基于vue+elementPlus的動態(tài)導(dǎo)航標(biāo)簽欄tabs的相關(guān)資料,本文主要詳述了在系統(tǒng)上添加導(dǎo)航標(biāo)簽欄功能時,首次嘗試的過程,并且希望能為同行提供一個小demo,需要的朋友可以參考下2024-10-10
vue動態(tài)路由加載時出現(xiàn)Cannot?find?module?xxx問題
這篇文章主要介紹了vue動態(tài)路由加載時出現(xiàn)Cannot?find?module?xxx問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-01-01

