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

.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);
    }
}


http://www.kler.cn/a/544562.html

相关文章:

  • 相机闪光灯拍照流程分析
  • 生成式AI应用提示注入攻击防御解决方案(上)
  • 渗透测试--文件包含漏洞
  • 编程语言错误处理机制的演变与 Go 的实践
  • 华为支付-商户基础支付场景开发步骤
  • 2025 西湖论剑wp
  • Baumer集成一体式相机堡盟一体式相机相机如何通过NeoAPI SDK使用自动对焦功能和可分区光源控制功能(C#)
  • 【闲谈集】学网络应用开发好还是学网络安全好?
  • 【Docker】从瀑布开发到敏捷开发
  • 从零开始:Django初学者的实战之旅
  • iMC U-Center开局部署、备份方案及授权介绍
  • 像指针操作、像函数操作的类
  • 【视频总结】Deep Dive into LLMs like ChatGPT 深入探索像ChatGPT这样的大语言模型|Andrej Karpathy
  • Vulhub靶机 MinIO信息泄露漏洞(CVE-2023-28432)(渗透测试详解)
  • CPP集群聊天服务器开发实践(二):点对点聊天和添加好友
  • 【Linux】玩转Linux操作系统(十二)网络访问和管理
  • 八.springboot集成mybatis+druid数据库连接池
  • 海外服务器都有什么作用?
  • 怎么用DeepSeek批量生成抖音脚本
  • unity 0基础自学2.2:射线与button UI的使用