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+tsc+noEmit导致打包报TS类型错误问题及解决方法

    vue+tsc+noEmit导致打包报TS类型错误问题及解决方法

    当我们新建vue3项目,package.json文件会自动给我添加一些配置选项,这写选项基本没有问题,但是在实际操作过程中,当项目越来越复杂就会出现问题,本文给大家分享vue+tsc+noEmit导致打包报TS类型错误问题及解决方法,感兴趣的朋友一起看看吧
    2023-10-10
  • Vue3项目引入阿里iconfont图标与字体及使用教程

    Vue3项目引入阿里iconfont图标与字体及使用教程

    Iconfont国内功能很强大且图标内容很丰富的矢量图标库,提供矢量图标下载、在线存储、格式转换等功能,下面这篇文章主要给大家介绍了关于Vue3项目引入阿里iconfont图标与字体及使用教程,需要的朋友可以参考下
    2023-05-05
  • Vue的表单双绑和组件你了解吗

    Vue的表单双绑和组件你了解吗

    这篇文章主要为大家详细介绍了Vue表单双绑和组件,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-03-03
  • 在Vue框架中配置Mock服务器的方法

    在Vue框架中配置Mock服务器的方法

    在前端开发中,如果需要模拟后端数据,而又不想开发一个后端服务器, 则可以借助mock.js配置一个后端服务器来返回前端需要的数据,本文将会分别介绍在Quasar项目和Vite项目中Mock服务器的配置方法
    2022-12-12
  • vue中定义全局声明vscode插件提示找不到问题解决

    vue中定义全局声明vscode插件提示找不到问题解决

    这篇文章主要为大家介绍了vue中定义全局声明vscode插件提示找不到问题解决,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-05-05
  • 使用 Vue 实现一个虚拟列表的方法

    使用 Vue 实现一个虚拟列表的方法

    这篇文章主要介绍了使用 Vue 实现一个虚拟列表的方法,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-08-08
  • vue.js云存储实现图片上传功能

    vue.js云存储实现图片上传功能

    示对象存储是腾讯云提供的一种存储海量文件的分布式存储服务,本文主要介绍了用vue.js实现图片上传功能,感兴趣的小伙伴们可以参考一下
    2021-05-05
  • 使用Vue实现防篡改的水印

    使用Vue实现防篡改的水印

    我们在平时上网的时候会看到有些图片是加水印的,一般水印往往是后端来做的,不过有些站点要保护的知识产权类型比较多,不光是图片,可能还有视频或者文字,所以我们水印的作用,就是给他做一个适当的限制,本文就给大家介绍一下如何使用Vue实现防篡改的水印
    2023-08-08
  • 详解vue项目首页加载速度优化

    详解vue项目首页加载速度优化

    这篇文章主要介绍了详解vue项目首页加载速度优化,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • Vue实现聊天界面

    Vue实现聊天界面

    这篇文章主要为大家详细介绍了Vue实现聊天界面,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-06-06

最新评论