gpt4 book ai didi

C#Blazor : Countdown Timer

转载 作者:行者123 更新时间:2023-12-03 16:54:46 26 4
gpt4 key购买 nike

我是C#的新手,正在尝试使用System.Timer.Timers创建一个简单的倒数计时器。它没有按预期工作,我在互联网上搜索了解决方案,但并没有真正解决我的问题。我想要的是当用户单击开始按钮时,它开始并显示倒计时。但是,尽管计时器有点用,但是当我单击一次按钮时,它并没有连续显示计时器,相反,我需要多次单击开始按钮才能看到倒数,否则计时器的显示不会改变。这是代码。

@page "/"

<h1>Timer</h1>

<p>@counter</p>
<button @onclick="StartTimer">Start</button>


@code {
private static System.Timers.Timer aTimer;
private int counter = 60;
public void StartTimer()
{
aTimer = new System.Timers.Timer(1000);
aTimer.Elapsed += CountDownTimer;
aTimer.Enabled = true;
}

public void CountDownTimer(Object source, System.Timers.ElapsedEventArgs e)
{
if (counter > 0)
{
counter -= 1;
}
else
{
aTimer.Enabled = false;
}
}

}

最佳答案

在更新计数器时调用StateHasChanged(),以便更新UI元素。
因为您的回调将在单独的线程上运行,所以您将需要使用InvokeAsync来调用StateHasChanged()。

public void CountDownTimer(Object source, ElapsedEventArgs e)
{
if (counter > 0)
{
counter -= 1;
}
else
{
aTimer.Enabled = false;
}
InvokeAsync(StateHasChanged);
}

关于C#Blazor : Countdown Timer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64797090/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com