当前位置: 首页 > news >正文

.NET 9.0 的 Blazor Web App 项目,进度条 <progress> 组件使用注意事项

一、执行过程中,要刷新 进度条 的显示,需要 延时、释放,否则进度条不 实时 更新,最后一下到 100%

 // 延时,释放给前端:【必须】,否则进度条不 实时 更新,最后一下到 100
 await Task.Delay(1);

二、执行过程中,需要 通知 Blazor 更新 UI,否则不 实时 更新

// 通知 Blazor 更新 UI:【必须】,否则不 实时 更新
StateHasChanged();

三、如果是单击执行,执行过程中,应该禁用 按钮,防止没有执行完毕就再次进入

// 禁用按钮
IsButtonDisabled = true;

四、示例程序

@page "/progress-demo"

<h3>进度条示例</h3>

<br />

<button @onclick="StartCalculation" disabled="@IsButtonDisabled">开始计算</button>

<br />
<br />

<progress value="@progressValue" max="100"></progress>

<p>进度: @progressValue%</p>

@code {
    private bool IsButtonDisabled { get; set; } = false;

    // 模拟 费时 计算
    void Calculation()
    {
        double d = 1.1;
        for (int i = 0; i < 1000000; i++)
        {
            d *= 9.9;
        }
    }

    // 进度条数值变量
    private int progressValue = 0;

    private async Task StartCalculation()
    {
        // 禁用按钮
        IsButtonDisabled = true;

        // 重置进度条
        progressValue = 0;
        // 开始 多次 费时 操作
        for (int i = 1; i <= 1000; i++)
        {
            // 这儿时 具体 费时 操作代码
            Calculation();

            // 更新一次进度条
            if (i % 10 == 0)
            {
                // 更改进度条数值
                progressValue++;
                // 输出到 Console 观察实际进度
                System.Console.WriteLine($"progressValue = {progressValue}, i = {i}");
                // 延时,释放给前端:【必须】,否则进度条不 实时 更新,最后一下到 100
                await Task.Delay(1);
                // 通知 Blazor 更新 UI:【必须】,否则不 实时 更新
                StateHasChanged();
            }
        }
        // 计算完成,确保 进度条 设置为 100%
        progressValue = 100;

        // 重新启用按钮
        IsButtonDisabled = false;
        await Task.FromResult(true);
    }
}

相关文章:

  • DeepSeek全生态接入指南:官方通道+三大云平台
  • 论文笔记:Multi-Head Mixture-of-Experts
  • Flutter 双屏双引擎通信插件加入 GitCode:解锁双屏开发新潜能
  • 麒麟操作系统-rabbitmq二进制安装
  • React 高级教程
  • 【ArcGIS Pro二次开发】(87):样式_Style的用法
  • 【Spring AI】基于SpringAI+Vue3+ElementPlus的QA系统实现(前端)
  • flutter ListView Item复用源码解析
  • MySQL Workbench工具 导出导入数据库
  • spring学习(spring-DI(setter注入、构造器注入、自动装配方式))
  • 在 CentOS 系统中配置交换空间(Swap)解决内存不足
  • Android和DLT日志系统
  • 13.推荐系统的性能优化
  • Go语言协程Goroutine高级用法(一)
  • 分布式版本控制系统---git
  • 【openresty服务器】:源码编译openresty支持ssl,增加service系统服务,开机启动,自己本地签名证书,配置https访问
  • 基于巨控GRM552YW-CHE:西门子S7-1200 PLC远程程序上下载与实时调试方案
  • spring cloud 使用 webSocket
  • 怎麼使用靜態住宅IP進行多社媒帳號管理
  • A4988一款带转换器和过流保护的 DMOS 微步驱动器的使用方式
  • 万达电影去年净利润亏损约9.4亿元,计划未来三年内新增25块IMAX银幕
  • “80后”商洛市委副书记、市政府党组副书记赵孝任商洛市副市长
  • 普京与卢卡申科举行会晤,将扩大在飞机制造等领域合作
  • 俄外长:俄将在不损害伙伴关系前提下发展对美关系
  • 中国人保不再设监事会,国寿集团未再设置监事长职务
  • 安徽省公安厅原副厅长刘海石主动投案,正接受审查调查