如何在Blazor Server应用程序的客户端上更新服务器端更改?

时间:2019-09-30 10:54:38

标签: blazor blazor-server-side

我的 ChangeValues 服务器端事件每5秒发生一次,但是在客户端,我只看到 number 变量的第一个值。 参见下面的代码

@page "/"
<button class="btn btn-primary" @onclick="ChangeValues">Click me</button>
<b>@number</b>
@code {
    double number;
    private Random rnd = new Random();
    private System.Threading.Timer _timer;
    void ChangeValues()
    {
        number = rnd.NextDouble();
        Console.WriteLine(number);
    }
    private void DoWork(object state)
    {
        ChangeValues();
    }
    protected override async Task OnInitializedAsync()
    {
        _timer = new System.Threading.Timer(DoWork, null, TimeSpan.Zero, 
            TimeSpan.FromSeconds(5));
    }
}

1 个答案:

答案 0 :(得分:1)

使用计时器(将在另一个线程上触发)时,您必须使用Invoke调用StateHasChanged():

private async void DoWork(object state)
{
    ChangeValues();
    await InvokeAsync(StateHasChanged);        
}