20行代码写一个简单 Blazor 时钟组件
群里有些同学询问怎么实现定时刷新界面, 那咱们写点试试看能不能达到需求.
代码比较简单, 就是Task每秒刷新页面. 然后封装为组件实现只局部刷新.
TimerAme.razor
<p>@Label @DateTime.Now.ToLongTimeString()</p>
TimerAme.razor.cs
using Microsoft.AspNetCore.Components;
public partial class TimerAme : ComponentBase, IDisposable
{
[Parameter]
public string Label { get; set; } = "时间:";
private CancellationTokenSource? AutoRefreshCancelTokenSource { get; set; }
protected override void OnInitialized() => worker();
/// <summary>
/// Dispose 方法
/// </summary>
public void Dispose() => AutoRefreshCancelTokenSource = null;
public void worker()
{
AutoRefreshCancelTokenSource = new CancellationTokenSource();
_ = Task.Run(async () =>
{
try
{
while (!(AutoRefreshCancelTokenSource?.IsCancellationRequested ?? true))
{
await InvokeAsync(StateHasChanged);
await Task.Delay(TimeSpan.FromSeconds(1), AutoRefreshCancelTokenSource?.Token ?? new CancellationToken(true));
}
}
catch (TaskCanceledException) { }
});
}
}
使用组件
<TimerAme />
关联项目
FreeSql QQ群:4336577
BA & Blazor QQ群:795206915
Maui Blazor 中文社区 QQ群:645660665
知识共享许可协议
本作品采用 知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议 进行许可。欢迎转载、使用、重新发布,但务必保留文章署名AlexChow(包含链接: https://github.com/densen2014 ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。如有任何疑问,请与我联系 。
转载声明
本文来自博客园,作者:周创琳 AlexChow,转载请注明原文链接:https://www.cnblogs.com/densen2014/p/18195194