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 进度条 组件进行开发

相关推荐
逐·風29 分钟前
unity关于自定义渲染、内存管理、性能调优、复杂物理模拟、并行计算以及插件开发
前端·unity·c#
Devil枫1 小时前
Vue 3 单元测试与E2E测试
前端·vue.js·单元测试
尚梦2 小时前
uni-app 封装刘海状态栏(适用小程序, h5, 头条小程序)
前端·小程序·uni-app
GIS程序媛—椰子2 小时前
【Vue 全家桶】6、vue-router 路由(更新中)
前端·vue.js
前端青山2 小时前
Node.js-增强 API 安全性和性能优化
开发语言·前端·javascript·性能优化·前端框架·node.js
毕业设计制作和分享3 小时前
ssm《数据库系统原理》课程平台的设计与实现+vue
前端·数据库·vue.js·oracle·mybatis
从兄4 小时前
vue 使用docx-preview 预览替换文档内的特定变量
javascript·vue.js·ecmascript
清灵xmf5 小时前
在 Vue 中实现与优化轮询技术
前端·javascript·vue·轮询
大佩梨5 小时前
VUE+Vite之环境文件配置及使用环境变量
前端
GDAL5 小时前
npm入门教程1:npm简介
前端·npm·node.js