首頁 > 後端開發 > C++ > 如何在 Blazor 中長時間運行的 API 呼叫期間動態顯示使用者回饋?

如何在 Blazor 中長時間運行的 API 呼叫期間動態顯示使用者回饋?

Patricia Arquette
發布: 2024-12-28 13:11:09
原創
466 人瀏覽過

How Can I Dynamically Show User Feedback During Long-Running API Calls in Blazor?

在Blazor 中的API 呼叫期間動態顯示使用者回饋

在Blazor 中,處理長時間運行的API 呼叫需要提供使用者回饋,例如顯示等待遊標或“旋轉”圖像。本文介紹了兩種實現此目的的方法:

選項 1:使用 Task.Delay(1)

  • 建立非同步方法。
  • 使用await Task.Delay(1);或等待 Task.Yield();刷新變更。
private async Task AsyncLongFunc()    // this is an async task
{
    spinning=true;
    await Task.Delay(1);      // flushing changes. The trick!!
    LongFunc();               // non-async code
    currentCount++;
    spinning=false;
    await Task.Delay(1);      // changes are flushed again    
}
登入後複製

選項 2:使用 Task.Run() (不適用於WebAssembly)

建立一個包含長操作的任務:

async Task AsyncLongOperation()    // this is an async task
{
    spinning=true;
    await Task.Run(()=> LongOperation());  //<--here!
    currentCount++;
    spinning=false;
}
登入後複製

效果預渲染

在Blazor Server 應用程式中,由於預渲染,微調器可能不會顯示。若要解決此問題,請在 OnAfterRender 中執行長操作,而不是 OnInitializedAsync。

protected override async Task OnAfterRenderAsync(bool firstRender)
{
    if (firstRender)
    {            
        await Task.Run(()=> LongOperation());//<--or Task.Delay(0) without Task.Run
        StateHasChanged();
    }
}
登入後複製

更多關於有效旋轉器實現的見解,請探索開源專案 BlazorPro.Spinkit。

以上是如何在 Blazor 中長時間運行的 API 呼叫期間動態顯示使用者回饋?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板