element-ui el-steps自定义进度图标及完成图标

在这里插入图片描述
项目中需要自定义 el-steps的图标 同时完成时图标也要进行修改,记录一下,有写的不好的地方欢迎大佬们指正:

实现步骤:

首先在templete部分:
el-step中添加一个插槽 slot=“icon”, 为其添加类名,以便于修改样式

<el-steps class="handlerSteps">
          <el-step
            @click.native="scrollToTop('build')"
            :status="flag_build ? 'success' : 'wait'"
            title="立项"
          >
            <i class="build stepIcon" slot="icon"></i>
          </el-step>
          <el-step
            @click.native="scrollToTop('design')"
            :status="flag_design ? 'success' : 'wait'"
            title="设计"
          >
            <i class="design stepIcon" slot="icon"></i>
          </el-step>
          <el-step
            @click.native="scrollToTop('bidding')"
            :status="flag_bidding ? 'success' : 'wait'"
            title="招标"
          >
            <i class="bidding stepIcon" slot="icon"></i>
          </el-step>
          <el-step
            @click.native="scrollToTop('doing')"
            :status="flag_doing ? 'success' : 'wait'"
            title="施工"
          >
            <i class="doing stepIcon" slot="icon"></i>
          </el-step>
          <el-step
            @click.native="scrollToTop('check')"
            :status="flag_check ? 'success' : 'wait'"
            title="验收"
          >
            <i class="check stepIcon" slot="icon"></i>
          </el-step>
          <el-step
            @click.native="scrollToTop('payProgress')"
            :status="flag_pay ? 'success' : 'wait'"
            title="进度支付"
          >
            <i class="pay stepIcon" slot="icon"></i>
          </el-step>
        </el-steps>

css部分:
记得不要写在 scoped中,否则不会生效, 这里是新开了一个style标签,所以没有写穿透
等待节点自定义图标:

.handlerSteps{
      .stepIcon{
        width: 35px;
        height: 35px;
        background-size: 100% 100%;
      }
      .build{
        background-image: url("~@/static/images/project/build.png");
      }
      .design{
        background-image: url("~@/static/images/project/design.png");
      }
      .bidding{
        background-image: url("~@/static/images/project/bidding.png");
      }
      .doing{
        background-image: url("~@/static/images/project/doing.png");
      }
      .check{
        background-image: url("~@/static/images/project/check.png");
      }
      .pay{
        background-image: url("~@/static/images/project/pay.png");
      }

成功状态自定义图标:

.el-step{
        &>.is-success{
          .is-icon{
              i{
              	//默认成功状态是在这个伪类中写的,因此覆盖掉这个√,写入自己的图片
                &:before{
                  content:"";
                }
                width:35px;
                height:35px;
                background-size: 100% 100%;
                background-image: url("~@/static/images/project/done.png");
              }
          }
        }
        .el-step__title{
          text-indent:6px;
        }
      }
  • 6
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值