返回顶部
首页 > 资讯 > 精选 >Vue如何实现渐变色进度条
  • 344
分享到

Vue如何实现渐变色进度条

2023-06-30 10:06:00 344人浏览 薄情痞子
摘要

这篇文章主要介绍“Vue如何实现渐变色进度条”,在日常操作中,相信很多人在Vue如何实现渐变色进度条问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue如何实现渐变色进度条”的疑惑有所帮助!接下来,请跟着小编

这篇文章主要介绍“Vue如何实现渐变色进度条”,在日常操作中,相信很多人在Vue如何实现渐变色进度条问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue如何实现渐变色进度条”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

功能要求

  • 进度条的总格子数可以自定义

  • 当前件数的占比和当前蓝色格子数对应

  • 格子的蓝色渐变要符合UI设计

首先确定props里面的值

即组件需要接收的值

这里只有名称、总数和当前值

props:{  name:{    type:String,    default:()=>('数据名称')  },  total:{    type:Number,    default:()=>(24)  },  value:{    type:Number,    default:()=>(18)  },},

然后就是主要的实现方法,这里接收一个cubeCount作为参数,即需要定义总格子数是多少

methods:{    initStatus(cubeCount){    //1.拿到总格子数div的宽度let totalDomWidth=this.$refs.total.offsetWidth;         //2.算出当前格子的比率        let ratio=(this.value/this.total);               //3.计算出每个格子的宽度        let cubeWidth=Math.floor((totalDomWidth/cubeCount)-1);             },  },

在计算每个格子的宽度的时候,用了Math.floor向下取整,至于后面的-1,是格子之间的间距

接着,根据每个格子的宽度,以及格子的数量,动态生成总的格子,插入到div中

 for(let i=0;i<cubeCount;i++){  let cubeDom=document.createElement('span');           cubeDom.style.background='#0F3D61'            cubeDom.style.width=cubeWidth+'px'           this.$refs.total.appendChild(cubeDom)}

接着根据之前算的比率算出当前的数值占了几个格子,这里也是向下取整

let nowCubeCount=Math.floor(cubeCount*ratio);

然后就是比较头痛的渐变色处理,这里我只取了第一个格子和最后一个格子的颜色,利用数组计算差值

let startColor=[16,139,247]; //RGB(16,139,247)let endColor=[15,218,250]; //RGB(15,218,250)let perDiffColor=[];  for(let i=0;i<endColor.length;i++){  perDiffColor.push( Number(((endColor[i]-startColor[i])/nowCubeCount).toFixed(3)))}

接着,给当前的格子数设置背景色,即初始的颜色+前格子的下标*每一份的颜色差值,这样组件就大致完成了

//拿到之前全部格子数cubeDomArr=this.$refs.total.children;   //给当前的格子设置颜色for(let i=0;i<nowCubeCount;i++){  cubeDomArr[i].style.background=  `RGB(    ${startColor[0]+i*perDiffColor[0]},    ${startColor[1]+i*perDiffColor[1]},    ${startColor[2]+i*perDiffColor[2]})  `}

然后去使用看看,效果如下:

    <dataitem     name="这里应该是当前的数据名称"     total=1267     value=500    ></dataItem>

Vue如何实现渐变色进度条

源代码如下

(mixin.sCSS样式文件没在,相信大家自己也能写出来)

<template>    <div class="box">        <div class="name" >{{name}}</div>        <div class="value" >          {{value}}          <span>件</span>        </div>        <div class="total" ref="total"></div>            </div></template>
<script>  export default {    name: "dataItem",    props:{      name:{        type:String,        default:()=>('数据名称')      },      total:{        type:Number,        default:()=>(24)      },      value:{        type:Number,        default:()=>(18)      },    },    data(){      return{      };    },    mounted(){      let that=this      this.initStatus(16);        },        updated() {      this.initStatus(16);    },    methods:{        initStatus(cubeCount){          let that=this;          let totalDomWidth=this.$refs.total.offsetWidth;            let ratio=(this.value/this.total);          let cubeWidth=Math.floor((totalDomWidth/cubeCount)-1);               let cubeDomArr;                         for(let i=0;i<cubeCount;i++){            let cubeDom=document.createElement('span');                     cubeDom.style.background='#0F3D61'                      cubeDom.style.width=cubeWidth+'px'                     this.$refs.total.appendChild(cubeDom)          }                          let nowCubeCount=Math.floor(cubeCount*ratio);                        cubeDomArr=this.$refs.total.children;                             let startColor=[16,139,247];           let endColor=[15,218,250];          let perDiffColor=[];                    for(let i=0;i<endColor.length;i++){            perDiffColor.push( Number(((endColor[i]-startColor[i])/nowCubeCount).toFixed(3)))          }                  for(let i=0;i<nowCubeCount;i++){            cubeDomArr[i].style.background=            `RGB(              ${startColor[0]+i*perDiffColor[0]},              ${startColor[1]+i*perDiffColor[1]},              ${startColor[2]+i*perDiffColor[2]})            `          }                            },    },  }</script>
<style lang="scss" scoped>    @import "./packages/common/style/mixin.scss";    .box{        width: px2vw(540);        height: px2vh(58);        position: relative;              }    .box .name{        position: absolute;        font-size: px2font(23);        color: #fff;        left: 0;        top: 0;    }    .box .total{        position: absolute;        left: 0;        bottom: 0;        width: 100%;        height: px2vh(15);       // border-radius: px2vh(7);       // background-color:#0F3F63;     //  border: 1px solid red;       display: flex;       justify-content: space-between;    }        .box .value{        position: absolute;        color: #fff;        font-size: px2font(30);        right: 0;        top: 0;    }        .box .value span{      font-size: px2font(23);    }</style>

到此,关于“Vue如何实现渐变色进度条”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: Vue如何实现渐变色进度条

本文链接: https://lsjlt.com/news/328165.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Vue如何实现渐变色进度条
    这篇文章主要介绍“Vue如何实现渐变色进度条”,在日常操作中,相信很多人在Vue如何实现渐变色进度条问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue如何实现渐变色进度条”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-06-30
  • Vue实现渐变色进度条的代码
    今天在封装一个个类似于下面这样的进度条组件 功能要求 进度条的总格子数可以自定义当前件数的占比和当前蓝色格子数对应格子的蓝色渐变要符合UI设计 这个渐变色的处理浪费了好一会功夫,下...
    99+
    2024-04-02
  • Android Canva如何实现渐变进度条
    本篇内容介绍了“Android Canva如何实现渐变进度条”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言标题说渐变进度条是为...
    99+
    2023-07-02
  • Android Canva实现渐变进度条
    目录前言1、拆分2、绘制圆环3、我要圆圆的头4、渐变来啦5、不能严丝合缝?逼死强迫症6、治理调皮的小圆前言 标题说渐变进度条是为了方便理解,这里本身的项目背景是一款表盘的分针。 先上...
    99+
    2024-04-02
  • JavaScriptcanvas实现环形渐变进度条
    最近有个需求要做环形渐变色进度条,去网上找了半天没找到合适的,大多数渐变色都是径向渐变,所以自己用canvas写了个环形渐变的图: 这个渐变其实就是把圆环分成许多小块分别绘制的,所...
    99+
    2024-04-02
  • css如何实现进度条的文字根据进度渐变
    这篇文章主要介绍css如何实现进度条的文字根据进度渐变,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体如下:需求1.进度条里面的文字需要根据进度的长度而变化原理用两个一模一样的样式...
    99+
    2024-04-02
  • android自定义进度条渐变色View的实例代码
    最近在公司,项目不是很忙了,偶尔看见一个兄台在CSDN求助,帮忙要一个自定义的渐变色进度条,我当时看了一下进度条,感觉挺漂亮的,就尝试的去自定义view实现了一个,废话不说,先...
    99+
    2022-06-06
    view 进度条 Android
  • Unity实现颜色渐变滑动条
    本文实例为大家分享了Unity实现颜色渐变滑动条的具体代码,供大家参考,具体内容如下 效果展示 代码 直接挂在UGUI Slider上即可 using UnityEngine;...
    99+
    2024-04-02
  • Android实现歌词渐变色和进度的效果
    要用TextView使用渐变色,那我们就必须要了解LinearGradient(线性渐变)的用法。 LinearGradient的参数解释 LinearGradient也称作线...
    99+
    2022-06-06
    渐变色 Android
  • Vue实现进度条变化效果
    本篇文章用Vue简单实现进度条的变化,供大家参考,具体内容如下 先上一波效果图: 点击减后,每次减百分之十 减到百分之0后,减操作按钮隐藏 然后点击重头开始,恢复到初始状态 ...
    99+
    2024-04-02
  • css怎么实现圆形渐变进度条效果
    这篇文章给大家分享的是有关css怎么实现圆形渐变进度条效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。实现思路最外面是一个大圆(渐变色)内部里面绘制两个半圆,将渐变的圆遮住(为了看起来明显,左右两侧颜色不一样,...
    99+
    2023-06-08
  • css中颜色渐变如何实现
    小编给大家分享一下css中颜色渐变如何实现,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!   一、LinearGradient...
    99+
    2024-04-02
  • css3如何实现字体渐变色
    今天小编给大家分享一下css3如何实现字体渐变色的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下...
    99+
    2024-04-02
  • CSS3如何实现彩色进度条动画
    这篇文章给大家分享的是有关CSS3如何实现彩色进度条动画的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。简要教程这是一款css3彩色进度条动画特效。该CSS3进度条动画特效中包含了三种动画特效,它们通过HMTL代码...
    99+
    2023-06-08
  • Android 自定义圆形带刻度渐变色的进度条样式实例代码
    效果图 一、绘制圆环 圆环故名思意,第一个首先绘制是圆环 1:圆环绘制函数 圆环API public void drawArc (RectF oval, float sta...
    99+
    2022-06-06
    渐变色 自定义 进度条 Android
  • css3如何实现文字颜色渐变
    这篇文章给大家分享的是有关css3如何实现文字颜色渐变的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   css3文字颜色渐变的方法一:通过css3的动画属性实现css文字动态...
    99+
    2024-04-02
  • html5如何实现Photoshop渐变色效果
    小编给大家分享一下html5如何实现Photoshop渐变色效果,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧! 代码如下: <!DOCTYPE html><head&...
    99+
    2024-04-02
  • 纯CSS如何实现文字渐变色
    这篇文章给大家分享的是有关纯CSS如何实现文字渐变色的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。什么是csscss是一种用来表现HTML或XML等文件样式的计算机语言,主要是用来设计网页的样式,使网页更加美化。...
    99+
    2023-06-14
  • android自定义进度条渐变圆形
    在安全卫生上,经常看到有圆形的进度条在转动,效果非常好看,于是就尝试去实现一下,具体实现过程不多说了,直接上效果图,先炫耀下。 效果图: 分析:比较常见于扫描结果、进度条等场...
    99+
    2022-06-06
    进度条 Android
  • css3实现border渐变色
    心血来潮 什么都不说 上代码 .gradualChange{width: 300px;height: 300px;border:20px solid;//兼容border-image: -webkit-linear-gradient(#00...
    99+
    2023-01-31
    渐变色 border
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作