• vue之tab栏切换


    一个简单的tab栏切换组件,由tabs以及tab-pane组成

    效果图
    在这里插入图片描述

    使用

    <template>
      <div class="container">
        <tabs
          default-active="2"
          class="build-tabs"
        >
          <tab-pane
            label="tab栏标题1"
            index="1"
          >tab栏内容1tab-pane>
          <tab-pane
            label="tab栏标题tab栏标题2"
            index="2"
          >
            tab栏内容2
          tab-pane>
          <tab-pane
            label="tab栏标题"
            index="3"
          >tab栏内容3tab-pane>
          <tab-pane
            label="标题"
            index="4"
          >tab栏内容4tab-pane>
          <tab-pane
            label="tab栏标题3"
            index="5"
          >tab栏内容5tab-pane>
        tabs>
      div>
    template>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31

    tabs

    <template>
      <div
        v-show="pans.length"
        class="tabs"
      >
        <div class="tab-title">
          <div
            v-for="(item) in pans"
            :key="item.id"
            class="item"
            :class="{ 'active': currentActive === item.index }"
            @click="changeTab(item.index)"
          >{{ item.label }}div>
        div>
        <div class="tab-content">
          <slot>slot>
        div>
      div>
    template>
    
    <script>
    export default {
      props: {
        mode: {
          type: String,
          default: "horizontal/vertical"
        },
        defaultActive: {
          type: String | Number,
          default: '1'
        },
        defaultColor: {
          type: String,
          default: '#409EFF'
        }
      },
      data: () => {
        return {
          currentActive: '',
          pans: []
        }
      },
      computed: {
    
      },
      watch: {
        defaultActive: {
          handler (newVal) {
            this.currentActive = newVal
          },
          immediate: true
        }
      },
      mounted () {
      },
    
      methods: {
        changeTab (val) {
          this.currentActive = val
        },
      }
    }
    script>
    <style scoped lang="scss">
    ::root {
      --color: "#409EFF";
    }
    .tabs {
      .tab-title {
        display: flex;
        // align-items: flex-start;
        align-items: stretch;	// 侧边栏时,使侧栏高度与内容高度一致,按最高的显示
        margin-bottom: 14px;
        border-bottom: 1px solid #ccc;
        .item {
          padding: 20px;
          /* padding-bottom: 20px; */
          cursor: pointer;
          white-space: nowrap;
        }
        .active {
          // color: var(--color);
          color: #409EFF;
          /* padding-bottom: 15px; // 修正边框值:20px - 5px = 15px */
          border-bottom: 5px solid #409EFF;
          background-image: linear-gradient(
            to top,
            rgba($color: #409EFF, $alpha: 0.2),
            transparent
          );
        }
      }
    }
    style>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95

    tab-pane

    <template>
      <div
        v-show="show && renderPan"
        class="tab-pane"
      >
        <slot>slot>
      div>
    template>
    <script>
    export default {
      name: 'tabPane',
      props: {
        index: {
          type: [String, Number],
          default: ''
        },
        label: {
          type: String,
          required: true
        }
      },
      data: () => {
        return {
          renderPan: false
        }
      },
      computed: {
        show () {
          if (this.$parent.currentActive === this.index) return true
          return false
        }
      },
      mounted () {
        this.$parent.pans.push({ id: Date.parse(new Date()) + Math.random(), index: this.index, label: this.label });
        this.renderPan = true
      },
      methods: {
      },
    }
    script>
    <style scoped lang="scss">
    style>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
  • 相关阅读:
    6.Dropout应用
    SpringBoot SpringBoot 开发实用篇 5 整合第三方技术 5.28 SpringBoot 整合 Kafka
    什么是IPQC(制程控制)?
    【算法】过桥
    Yarn重启applications记录恢复
    STL String类详解(上)
    structs2 重构成SpringBoot架构
    【牛客刷题】前端--JS篇(二)
    记一次http接口自动重试现象的排查
    初识爬虫自我感受
  • 原文地址:https://blog.csdn.net/wgh4318/article/details/126215160