react实现数据进度条展示组件

1.需求

在项目开发时,要展示一个操作的进度条,比如:要实现一个文件的上传下载进度条,或者实现类似拼夕夕砍一刀进度条,怎么实现呢?效果图如下:

对上面效果图说明:

进度条底色为棕黑色(#043330,或者自定义一个进度条图片),进度条为黄色(#f1e60a,或者自定义一个进度条图片),比如:

进度条里面的文案颜色为白色(#fff)

2.实现

把上面需要实现的功能写成一个组件,页面直接调用该组件即可,代码如下:
要引入组件页面的代码:

javascript 复制代码
import React, {useState} from "react";
import axios from "axios";
import Scroll from "../../components/Scroll";
 
const Index = () => {
     //进度条要达到的总值
     const [proTotal,setProTotal] = React.useState(500);
     //进度条当前的值
     const [proCur,setProCur] = React.useState(500);
    useEffect(() => {
        //通过api接口从服务端获取配置参数
        let result = await axios({
                method: "post",
                url: "服务端apiurl地址",
                data: JSON.stringify({
                      "服务端请求api接口",
                      {"请求参数名": "请求参数值"},
                }),
                headers: {
                  "Content-Type": "application/x-www-form-urlencoded;charset=UTF-8",
                },
          });
        
        //设置配置
        setProTotal(result.proTotal);
        setProCur(result.proCur);
    });
 return (
        <div class={style.main}>
                 <Progress
                     width="100%"
                     height={"0.73rem"}
                     borderRadius={"1.2rem"}
                     percentage={(preCur / proTotal) * 100}
                     textColor={"#fff"}
                     fontSize={"0.6rem"}
                     progressColor={"#f1e60a"}
                     backgroundColor={"#043330"}
                     text={`${reCur} / ${proTotal}`}
                 />
        </div>
    )
}
 
export default Index;

对上面Progress参数说明:

width: 进度条宽度,

height:进度条高度,

borderRadius:进度条边框圆弧半径,

percentage:进度条百分比(主要用于显示黄色进度条多少),

textColor:进度条中间说明文案颜色,

text:进度条中间的文案说明

fontSize:进度条中间说明文案字体大小,

progressColor:进度条颜色:

可以是颜色二进制,还可以是一张图片,比如:

progressColor={"#f1e60a"}

progressColor={""url('../images/progrssCplor.png') 100%"} (图片如上面所示)

backgroudColor:进度条背景色:同progressColor一样
组件:

javascript 复制代码
import React from "react";

const Progress = ({
      percentage,
      width,
      height,
      borderRadius,
      backgroundColor,
      fontSize,
      textColor,
      text
  }) => {
    return (
        <div style={{ width, height, borderRadius, backgroundColor, overflow: "hidden" }}>
            <div
                style={{
                    width: "100%",
                    height: "100%",
                    textAlign: "center",
                    display: "flex",
                    justifyContent: "center",
                    alignItems: "center",
                }}
            >
                <span
                    style={{
                        fontSize,
                        fontWeight:700,
                        color: textColor,
                    }}
                >
                  {text}
                </span>
            </div>
            <div style={{ background: progressColor,backgroundSize: `${100}% ${percentage}%`, marginTop: `-${height}`, height, width: `${percentage}%`, borderRadius: borderRadius }} />
        </div>
    );
};

export default Progress;

对上面代码说明:
Progress中的参数为请求组件时传入的参数,

第一个div是进度条底图div,

第二个div是进度条中间文案div,

第三个div是进度条进度div

好了,进度条代码组件就好了,当然,也可以参考react-vant的Progress 进度条 组件进行开发

相关推荐
编程零零七1 小时前
Python数据分析工具(三):pymssql的用法
开发语言·前端·数据库·python·oracle·数据分析·pymssql
北岛寒沫2 小时前
JavaScript(JS)学习笔记 1(简单介绍 注释和输入输出语句 变量 数据类型 运算符 流程控制 数组)
javascript·笔记·学习
everyStudy2 小时前
JavaScript如何判断输入的是空格
开发语言·javascript·ecmascript
(⊙o⊙)~哦3 小时前
JavaScript substring() 方法
前端
无心使然云中漫步4 小时前
GIS OGC之WMTS地图服务,通过Capabilities XML描述文档,获取matrixIds,origin,计算resolutions
前端·javascript
Bug缔造者4 小时前
Element-ui el-table 全局表格排序
前端·javascript·vue.js
xnian_4 小时前
解决ruoyi-vue-pro-master框架引入报错,启动报错问题
前端·javascript·vue.js
麒麟而非淇淋5 小时前
AJAX 入门 day1
前端·javascript·ajax
2401_858120535 小时前
深入理解MATLAB中的事件处理机制
前端·javascript·matlab
阿树梢5 小时前
【Vue】VueRouter路由
前端·javascript·vue.js