仿照elementUI写个步骤条

效果图如下:

直接上代码:

bash 复制代码
<template>
  <div class="">
    <div class="steps">
      <div class="step" v-for="(step, index) in steps" :key="index">
        <div
          class="icon"
          @click="currentStep = index"
          :class="{ icon: true, 'active-icon': currentStep == index }"
        >
          <div class="cir">{{ index + 1 }}</div>
          <div class="title">{{ step }}</div>
        </div>
        <div v-if="index < steps.length - 1" class="line"></div>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      steps: ["投标函格式", "评标原则", "评标方法", "招标文件"],
      currentStep: 0,
    };
  },
  created() {},
  mounted() {},
  methods: {},
};
</script>

<style lang='scss' scoped>
.steps {
  width: 100%;
  display: flex;

  .step {
    flex: 1;
    display: flex;
    line-height: 25px;
    position: relative;
    .icon {
      position: relative;
      z-index: 1;
      background: #fff;
      padding: 0 10px;
      display: flex;
      cursor: pointer;
      color: #00000073;

      .cir {
        width: 25px;
        height: 25px;
        text-align: center;
        line-height: 25px;
        box-sizing: border-box;
        border-radius: 50%;
        border: 1px solid #00000073;
      }
      .title {
        margin-left: 10px;
        width: auto;
      }
      &:hover {
        color: #1989fa;
        .cir {
          color: #1989fa;
          border: 1px solid #1989fa;
        }
      }
    }
    .active-icon {
      color: #1989fa;
      .cir {
        color: #fff;
        border: 1px solid #1989fa;
        background-color: #1989fa;
      }
      &:hover {
        .cir {
          color: #fff;
        }
      }
    }

    .line {
      margin-left: 5px;
      background-color: #e8e8e8;
      flex: 1;
      position: absolute;
      top: 12px;
      left: 0;
      right: 0;
      height: 1px;
    }
  }
}
.steps .step:last-child {
  flex-basis: auto !important;
  flex-shrink: 0;
  flex-grow: 0;
}
</style>
相关推荐
江城开朗的豌豆38 分钟前
Vuex数据突然消失?六招教你轻松找回来!
前端·javascript·vue.js
好奇心笔记1 小时前
ai写代码随机拉大的,所以我准备给AI出一个设计规范
前端·javascript
江城开朗的豌豆1 小时前
Vue状态管理进阶:数据到底是怎么"跑"的?
前端·javascript·vue.js
我想说一句1 小时前
React待办事项开发记:Hook魔法与组件间的悄悄话
前端·javascript·前端框架
真夜1 小时前
CommonJS与ESM
前端·javascript
G等你下课1 小时前
从点击到执行:如何优雅地控制高频事件触发频率
前端·javascript·面试
Jackson_Mseven1 小时前
面试官:说说 startTransition 和 useDeferredValue?我:我用它一行代码救了首页!
前端·javascript·面试
架构个驾驾1 小时前
从0到1搭建Vue3+Vant移动端项目(一)
前端·javascript·vue.js
然我1 小时前
React 中 useEffect 到底怎么用才不会踩坑?全流程详解 + 实例讲透副作用
前端·javascript·react.js
前端付豪1 小时前
12、表单系统设计:动态表单 + 校验 + 可配置化
前端·javascript·架构