vue elementUi中的tabs标签页使用教程

 更新时间:2023年03月23日 14:34:13   作者:颅骨锅炉  
Tabs 组件提供了选项卡功能,默认选中第一个标签页,下面这篇文章主要给大家介绍了关于vue elementUi中的tabs标签页使用的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下

前言

详细介绍如何添加Tabs标签页,很简单的东西,但感觉教程很少,刚刚研究好久才弄好,记录下希望对需要者有帮助。

一、整体页面布局与完成效果

整体界面(mainview.vue)布局如下图:

在红色框部分添加标签页

代码结构

标签页主要在mainview中编写

//mainview.vue
<template>
<el-container>
        <el-header>header顶部栏</el-header>
        <el-container>
            <el-aside>
            aside侧边栏
            <leftbar></leftbar>//leftbar.vue
            </el-aside>
            <el-main>main主界面
            		<el-tabs>标签页
            			<el-tab-pane>
            				标签页显示区域
            			</el-tab-pane>
            		</el-tabs>
            </el-main>
        </el-container>
    </el-container>
 <template>

即在Main中添加Tabs标签页,实现在侧边栏中点击功能键后,在图中红色框部分出现标签,点击可跳转界面。

登陆默认“首页界面”开启且不可关闭,其余界面可手动开启,手动关闭。
完成效果如下图:

二、代码编写

1.标签页引入

标签页代码如下

	<el-tabs class="tabs" 
	         v-model="editableTabsValue" 
             type="border-card" 
             @tab-remove="removeTab"
             @tab-click="clickTab">
           <el-tab-pane class="tab-pane" 
           				v-for="item in editableTabs" 						      
           				:closable="item.close" 
                        :key="item.name" 
                        :label="item.title" 
                        :name="item.name" >
                         {{item.content}}
                        <RouterView></RouterView>//标签页界面路由显示
            </el-tab-pane>
     </el-tabs>

2.标签页参数设置

2.1 标签页主要参数

标签页的数据存放在vuex的store中,在store.state中添加两个参数的定义,设置的初始数据为“首页界面”的数据。

state: {
    	//当前打开的界面路由,初始值为主页的路由
    editableTabsValue:'/mainview/index',
    //存放当前打开的标签页的数组,初始时只有首页
    editableTabs:[{
      title:'首页',//标签页名
      name:'/mainview/index',//标签页路由
      close:false//该标签页是否可关闭,这里是首页标签页不可被关闭
    }]
  },

2.2 打开和切换标签页方法

然后在mutation中添加两个方法,操作这两个参数,以控制标签页的打开和切换。

ADD_TABS:(state,tab)=>{//增加标签页方法
	//在editableTabs中查找此界面是否已打开,否进入if
   if(state.editableTabs.findIndex(e=>e.name===tab.path)===-1){
        state.editableTabs.push({//添加当前标签页进入editableTabs
          title:tab.name,
          name:tab.path,
          close:true//使除了首页标签页外其他都可关闭
        })
      }
      state.editableTabsValue=tab.path//添加标签页后默认打开
},
CHANGE_TABS:(state,name)=>{//切换标签页方法
		 //将需打开标签页路由赋予editableTabsvalue
      state.editableTabsValue=name
},

2.3 mainview中添加数据

在mainview的data中添加并获取state中的数据,注意引入ref

2.4 侧边栏相关设置

在leftbar.vue的data中添加参数submenuList,用于存放侧边导航栏栏位数据。

此处代码为elementUI导航栏代码,不做过多解释,注意添加opentab方法。

2.5 标签页的打开

opentab方法,点击侧边栏栏位以打开标签页,调用ADD_TABS方法。

注意:1、导入store 2、此方法写在leftbar.vue中,也就是说只有点击侧边栏才能打开标签页。

侧边栏效果如下图:

3.标签页的切换和关闭

3.1切换标签页方法

前面已经在store的mutation中写过打开(ADD_TABS)和切换(CHANGE_TABS)两个方法了,opentab写在侧边栏(leftbar.vue)中,调用了打开方法(ADD_TABS)以实现点击侧边栏打开标签页。

调用切换(CHANGE_TABS)的方法则要写在mainview中,如下图。

在method中添加clickTab方法

clickTab(tab){
            var name=JSON.stringify(tab.paneName).replace('"','').replace('"','')//对tab参数处理,以获得当前点击的标签页的路由
            store.commit('CHANGE_TABS',name)//调用切换方法切换标签页
            router.push(name)//路由跳转以实现切换界面
    }

3.2 刷新方法

我们需要一个方法在更新完state中的参数,同步更新mainview中的参数。

refreshTabs(){
        // console.log("refresh");
        this.editableTabsValue=store.state.editableTabsValue;
        this.editableTabs=store.state.editableTabs;
    },

代码很简单,直接赋值就可以,重要的是需要在state数据更新时,同步更新mainview中数据,所以需要搞一个监听器,调用refreshTabs方法以实现同步更新数据。

3.3 监听以同步数据

在mainview的watch中,监听state,如有变化则同步更新数据,这样就实现了点击标签页后的实时切换。

watch:{
    "$store.state":{
            deep:true,
            handler:function(){
                this.refreshTabs();
            }
        },

3.4 标签页的关闭

在mainview的method中添加removeTab方法,这里我直接复制了elementUI中的removeTab方法。
这个方法可以实现,关闭一个标签页后,会自动打开旁边的标签页。

removeTab(targetName) {
        let tabs = this.editableTabs;
        let activeName = this.editableTabsValue;
        if (activeName === targetName) {
          tabs.forEach((tab, index) => {
            if (tab.name === targetName) {
              let nextTab = tabs[index + 1] || tabs[index - 1];
              if (nextTab) {
                activeName = nextTab.name;
              }
            }
          });
        }
        store.state.editableTabsValue=activeName;
        store.state.editableTabs=tabs.filter(tab=>tab.name!==targetName);
        router.push(activeName)
    },

总结

到此这篇关于vue elementUi中tabs标签页使用的文章就介绍到这了,更多相关elementUi中tabs标签页使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 有关vue 组件切换,动态组件,组件缓存

    有关vue 组件切换,动态组件,组件缓存

    这篇文章主要介绍了有关vue 组件切换,动态组件,组件缓存,在组件化开发模式下,我们会把整个项目拆分成很多组件,然后按照合理的方式组织起来,达到预期效果,下面来看看文章的详细内容
    2021-11-11
  • vue启动报错‘vue-cli-service serve‘问题及解决

    vue启动报错‘vue-cli-service serve‘问题及解决

    这篇文章主要介绍了vue启动报错‘vue-cli-service serve‘问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • Vue3中关于ref和reactive的区别分析

    Vue3中关于ref和reactive的区别分析

    这篇文章主要介绍了vue3关于ref和reactive的区别分析,文中通过示例代码介绍的非常详细,具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧
    2023-06-06
  • 搭建vue开发环境

    搭建vue开发环境

    这篇文章主要介绍了搭建vue开发环境的方法,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-07-07
  • vue3通过组合键实现换行操作的示例详解

    vue3通过组合键实现换行操作的示例详解

    这篇文章主要为大家详细介绍了vue3如何通过组合键,例如command+Enter、shift+Enter、alt + Enter,实现换行操作,感兴趣的可以了解下
    2024-03-03
  • vue实现鼠标经过显示悬浮框效果

    vue实现鼠标经过显示悬浮框效果

    这篇文章主要为大家详细介绍了vue实现鼠标经过显示悬浮框效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • Vue3实战学习配置使用vue router路由步骤示例

    Vue3实战学习配置使用vue router路由步骤示例

    这篇文章主要为大家介绍了Vue3实战学习配置使用vue router路由步骤示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • 深入探究Vue2响应式原理的实现及存在的缺陷

    深入探究Vue2响应式原理的实现及存在的缺陷

    Vue的响应式数据机制是其核心特性之一,它能够自动追踪数据的变化,并实时更新相关的视图,然而,Vue2中的响应式数据机制并非完美无缺,本文将探讨Vue2响应式原理及其存在的缺陷
    2023-08-08
  • vue 刷新之后 嵌套路由不变 重新渲染页面的方法

    vue 刷新之后 嵌套路由不变 重新渲染页面的方法

    今天小编就为大家分享一篇vue 刷新之后 嵌套路由不变 重新渲染页面的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • 基于electron+vue3+ts搭建桌面端应用并且可以热更新

    基于electron+vue3+ts搭建桌面端应用并且可以热更新

    这篇文章主要为大家详细介绍了如何基于electron+vue3+ts搭建桌面端应用并且可以热更新,文中的示例代码讲解详细,感兴趣的小伙伴可以参考下
    2023-10-10

最新评论