基于React和antd实现自定义进度条的示例代码

 更新时间:2025年03月26日 09:21:23   作者:五号厂房  
在现代 Web 开发中,进度条是一种常见且实用的 UI 组件,用于直观地向用户展示任务的完成进度,本文将详细介绍如何使用 React 来构建一个自定义的进度条,它不仅能够动态展示进度,还具备额外的信息提示功能,需要的朋友可以参考下

一、技术选型与准备

我们选用了广受欢迎的 React 框架作为核心开发工具,它提供了高效的组件化开发模式,让代码的组织与维护变得更加便捷。同时,为了实现一些精致的交互效果,引入了 Ant Design(简称 antd)库中的 Tooltip 组件。Ant Design 是一套成熟的企业级 UI 设计语言和 React 组件库,能够助力我们快速搭建出美观且功能强大的界面。

二、组件的核心逻辑

(一)状态管理

首先,定义一个名为 BasedOnReactSelfDefinedProgressBar 的函数式 React 组件:

import React, { useState, useEffect } from "react";
import { Tooltip } from "antd";

const BasedOnReactSelfDefinedProgressBar: React.FC = () => {
  const [progressData, setProgressData] = useState([
    { percent: 10, color: "red" },
    { percent: 10, color: "green" },
    { percent: 10, color: "red" },
    { percent: 10, color: "green" },
    { percent: 10, color: "green" },
  ]);

在这里,通过 useState 钩子函数初始化了一个名为 progressData 的状态变量,它存储着进度条的关键信息。这个状态是一个数组,数组中的每个元素都是一个对象,包含 percent(表示当前片段的进度占比)和 color(用于区分不同类型,在后续示例中与岩石类型相关联,红色代表火成岩,绿色代表沉积岩)两个属性。初始状态下,设定了各个片段具有相同的起始占比 10%。

(二)动态更新机制

为了让进度条能够自动推进,使用 useEffect 钩子函数来处理副作用:

  useEffect(() => {
    const interval = setInterval(() => {
      setProgressData(prev => 
        prev.map(item => ({
         ...item,
          percent: Math.min(prev.reduce((sum, cur) => sum + cur.percent, 0) + 10, 100)
        }))
      );
    }, 1000);
    return () => clearInterval(interval);
  }, []);

当组件挂载时,创建一个定时器(setInterval),每隔 1 秒钟触发一次更新操作。在更新函数中,通过获取前一状态 prev,对 progressData 数组中的每个元素进行处理。新的 percent 值是将当前所有元素的 percent 之和加上 10,但使用 Math.min 确保最终结果不超过 100%,以符合进度条的实际意义。同时,为了避免内存泄漏,在组件卸载时,通过返回的清除函数 clearInterval(interval) 及时关闭定时器。

三、组件的渲染呈现

  return (
    <div
      style={{
        width: "100%",
        height: "10px",
        background: "#e0e0e0",
        position: "relative",
        borderRadius: "10px",
        overflow: "hidden"
      }}
    >
      {progressData.map((item, index) => (
        <Tooltip 
          key={index} 
          title={`岩石类型: ${item.color === 'red'? '火成岩' : '沉积岩'}\n占比: ${item.percent}%`}
        >
          <div
            style={{
              width: `${100 / progressData.length}%`,
              height: "100%",
              background: item.color,
              position: "absolute",
              left: `${(100 / progressData.length) * index}%`,
              borderRadius: '5px',
              transition: 'width 0.3s ease'
            }}
          />
        </Tooltip>
      ))}
    </div>
  );
};

export default BasedOnReactSelfDefinedProgressBar;

显示效果:

综上所述,通过以上步骤,利用 React 结合 antd 的 Tooltip 组件,成功构建了一个既具备动态进度更新功能,又拥有丰富信息提示的自定义进度条。在实际项目中,可根据具体需求进一步拓展其功能,比如添加更多的进度条样式、响应不同的交互事件等,使其更好地服务于各类业务场景。

以上就是基于React和antd实现自定义进度条的示例代码的详细内容,更多关于React antd自定义进度条的资料请关注脚本之家其它相关文章!

相关文章

  • React Antd Upload组件上传多个文件实现方式

    React Antd Upload组件上传多个文件实现方式

    为实现多文件上传,需使用beforeUpload和customRequest替代onChange以避免多次调用问题,并处理文件路径以兼容Electron不同平台
    2025-08-08
  • React中redux的使用详解

    React中redux的使用详解

    Redux 是一个状态管理库,它可以帮助你管理应用程序中的所有状态,Redux的核心概念之一是Store,它表示整个应用程序的状态,这篇文章给大家介绍React中redux的使用,感兴趣的朋友一起看看吧
    2023-12-12
  • 在React中编写class样式的方法总结

    在React中编写class样式的方法总结

    在TypeScript (TSX) 中编写 CSS 样式类有几种方法,包括使用纯 CSS、CSS Modules、Styled Components 等,本文给大家介绍了几种常见方法的示例,通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-07-07
  • 如何使用React构建一个掷骰子的小游戏

    如何使用React构建一个掷骰子的小游戏

    这篇文章主要介绍了如何使用React构建一个掷骰子的小游戏,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-12-12
  • 在React中引入CSS的各种方式详解

    在React中引入CSS的各种方式详解

    React是一个用于构建用户界面的JavaScript库,广泛应用于现代Web开发中,在React应用中,引入CSS样式是实现美观界面的重要环节,本文将详细探讨在React中引入CSS的各种方式,并分析各自的优缺点,需要的朋友可以参考下
    2025-06-06
  • React前端开发createElement源码解读

    React前端开发createElement源码解读

    这篇文章主要为大家介绍了React前端开发createElement源码解读,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-11-11
  • React Native 中集成 MinIO 对象存储的最佳实践(图片/文件上传服务)

    React Native 中集成 MinIO 对象存储的最佳实践(图片/文件上传

    本文介绍了从环境配置到实际应用的完整流程,包括核心功能实现、最佳实践和常见问题解决方案,希望这些内容能帮助你在 React Native 项目中更好地使用 MinIO,感兴趣的朋友跟随小编一起看看吧
    2026-04-04
  • 解读react的onClick自动触发等相关问题

    解读react的onClick自动触发等相关问题

    这篇文章主要介绍了解读react的onClick自动触发等相关问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-02-02
  • 详解React Native中如何使用自定义的引用路径

    详解React Native中如何使用自定义的引用路径

    这篇文章主要为大家介绍了React Native中如何使用自定义的引用路径详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • React中的useMemo 和 useEffect 执行顺序

    React中的useMemo 和 useEffect 执行顺序

    在 React 组件的渲染过程中,useMemo 和 useEffect 的执行顺序是不同的,本文给大家介绍React中的useMemo 和 useEffect 哪个先执行,感兴趣的朋友一起看看吧
    2025-01-01

最新评论