element修改Progress 进度条的背景色以及设置进度条颜色渐变

前言:

最近在做大屏可视化项目、用于展示项目的总体数据。在开发过程中、要求用轮循获取数据源、实时更新数据的进度、前台做出进度展示。

功能实现:

因为项目使用的UI框架是element、所以这里以element为例、实现数据进度的展示。

UI原型图:

在这里插入图片描述

elemet-ui提供Progress 进度条组件、直接引用即可。但是引入组件的样式是默认的、达不到我们的要求。
在这里插入图片描述

修改Progress进度条背景色

想要直接修改element组件的css样式值 需要加/deep/ 或者 >>> 实现样式穿透

HTML

<div class="progress"> 
    <el-progress :width="60" :hidden="60" type="circle" :percentage="50"></el-progress> 
</div>

CSS

<style lang="scss" scoped> // 此处使用的是scss语法 可以调整 不影响 
    .case-progress { 
        svg>path:nth-child(2) { 
            stroke: url(#write); // #write 此处的id就是定义的svg标签id 做替换即可 
        } 
    } 
</style>

修改Progress进度条颜色渐变

element中圆形进度条是由svg绘制渲染出来的、我们只能修改svg标签的色度起始值

HTML

声明svg标签即可、为了方便后续修改element进度条颜色渐变

<!-- 定义修改svg --> 
<div style="width:0px; height: 0px;"> 
    <svg width="100%" height="100%"> 
        <defs> 
            <linearGradient id="write" x1="0%" y1="0%" x2="100%" y2="0%"> 
                <stop offset="0%" style="stop-color:#0299E2" stop-opacity="0.8"></stop> // offset 设置起始 stop-color 设置起始位置的颜色 
                <stop offset="100%" style="stop-color:#02E4DC" stop-opacity="1"></stop> // offset 设置起始 stop-color 设置起始位置的颜色 
            </linearGradient> 
        </defs> 
    </svg> 
</div> 
<div class="progress"> 
    <el-progress :width="60" :hidden="60" type="circle" :percentage="50"></el-progress> 
</div>

CSS

<style lang="scss" scoped> // 此处使用的是scss语法 可以调整 不影响 
    .case-progress { 
        svg>path:nth-child(2) { 
            stroke: url(#write); // #write 此处的id就是定义的svg标签id 做替换即可 
        } 
    } 
</style>

效果展示

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值