Springboot集合前端实现进度条显示功能实例

 更新时间:2024年11月28日 10:38:38   作者:知识浅谈  
这篇文章主要介绍了使用进度条提升用户体验的原因,特别是在处理大文件上传、下载或长时间运行的操作时,进度条通过实时反馈任务进度,减少用户的不确定感,文中给出了详细的代码示例,需要的朋友可以参考下

项目为什么使用进度条

前端使用进度条显示的主要原因是提升用户体验。它能让用户了解当前操作的进度和剩余时间,减少不确定感。

特别是在处理大文件上传、下载或长时间运行的操作时,进度条可以提供视觉反馈,避免用户感到操作卡顿或无响应,从而提升整体使用满意度。

进度条涉及技术

  • 线程:进度条所对应的内容一般是新建一个线程进行处理,因为所需要处理的时间相对较长。
  • Redis:要实时反馈给前端当前任务的进度,每执行一步,及时更新执行的进度。
  • ProgressBar:前端可以使用对应的进度条组件,比如ProgressBar。

代码实现

使用new Thread新建一个线程对业务进行处理,并不断更新Redis中的值,实时维护进度和总量,确保前端能查到这个比例关系。

  • 调用业务处理接口:该接口中包含较长时间的处理过程
      @GetMapping("/startProgress")
        public R startProgress() {
            String key = IdUtil.getSnowflakeNextIdStr();
            Result result = new Result();
            result.setStatus("0");
            result.setProceed(0);
            result.setTotal(100);
            result.setMsg("文件处理中...");
            RedisUtils.setCacheObject("Test:"+key,result, Duration.ofMinutes(2L)); //
    
            new Thread(()->{
                for (int i = 0; i < 100; i++) {
                    try {
                        Thread.sleep(100);
                        //每做完一个实时更新
                        Result result1 = RedisUtils.getCacheObject(key);
                        result1.setProceed(result1.getProceed()+1);
                        RedisUtils.setCacheObject(key,result1);
                    } catch (InterruptedException e) {
                        throw new RuntimeException(e);
                    }
                }
                Result result1 = RedisUtils.getCacheObject(key);
                result1.setStatus("1");
                result1.setMsg("文件处理完成");
                RedisUtils.setCacheObject(key,result1);
            }).start();
            return R.ok("操作成功",key);
        }
    
        @Data
        class Result{
            String status;
            Integer total;
            Integer proceed;
            String msg;
        }
    
    
  • 轮询业务处理进度
    @GetMapping("/redis/{key}")
    public R find(@PathVariable String key){
        return R.ok(RedisUtils.getCacheObject(key));
    }
    

总结

到此这篇关于Springboot集合前端实现进度条显示功能的文章就介绍到这了,更多相关Springboot前端实现进度条显示内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • java实现读取、删除文件夹下的文件

    java实现读取、删除文件夹下的文件

    本文给大家分享的是java实现读取、删除文件夹下的文件,其中File.delete()用于删除“某个文件或者空目录”!所以要删除某个目录及其中的所有文件和子目录,要进行递归删除,有需要的小伙伴可以参考下。
    2015-05-05
  • springBoot下实现java自动创建数据库表

    springBoot下实现java自动创建数据库表

    这篇文章主要介绍了springBoot下实现java自动创建数据库表的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • java配置文件取值的多种方式总结

    java配置文件取值的多种方式总结

    这篇文章主要为大家详细介绍了java配置文件取值的多种方式,包括一般项目,国际化项目,springboot项目,文中的示例代码讲解详细,需要的可以参考下
    2023-11-11
  • Java链表元素查找实现原理实例解析

    Java链表元素查找实现原理实例解析

    这篇文章主要介绍了Java链表元素查找实现原理实例解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-07-07
  • mybatis一对一查询功能

    mybatis一对一查询功能

    所谓的一对一查询,就是说我们在查询一个表的数据的时候,需要关联查询其他表的数据。这篇文章主要介绍了mybatis一对一查询功能,需要的朋友可以参考下
    2017-02-02
  • 关于springboot 中使用httpclient或RestTemplate做MultipartFile文件跨服务传输的问题

    关于springboot 中使用httpclient或RestTemplate做MultipartFile文件跨服务传输

    这篇文章主要介绍了关于springboot 中使用httpclient或RestTemplate做MultipartFile文件跨服务传输的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • Maven3.9.9环境安装配置的实现步骤

    Maven3.9.9环境安装配置的实现步骤

    Maven是一个强大的项目管理和构建自动化工具,本文主要介绍了Maven3.9.9环境安装配置的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-05-05
  • java Swing组件setBounds()简单用法实例分析

    java Swing组件setBounds()简单用法实例分析

    这篇文章主要介绍了java Swing组件setBounds()简单用法,结合实例形式分析了Swing组件setBounds()方法的功能与简单使用方法,需要的朋友可以参考下
    2017-11-11
  • Java项目启动成功、失败信息实时反馈提醒问题(邮件或者短信)

    Java项目启动成功、失败信息实时反馈提醒问题(邮件或者短信)

    这篇文章主要介绍了Java项目启动成功、失败信息实时反馈提醒问题(邮件或者短信),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • 如何解决遇到的错误信息 java: 找不到符号 符号: 变量 log

    如何解决遇到的错误信息 java: 找不到符号 符号: 变量 log

    使用Lombok的@Slf4j注解时出现log变量找不到问题,这篇文章主要介绍了如何解决遇到的错误信息 java: 找不到符号 符号: 变量 log的相关资料,文中将解决的办法介绍的非常详细,需要的朋友可以参考下
    2025-05-05

最新评论