微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Blazor Webassembly,状态管理刷新子组件

如何解决Blazor Webassembly,状态管理刷新子组件

我正在从列表中选择项目,并显示它们的不同内容。 此代码可以正常工作:

public class ItemState
{
    public Item CurrentItem { get; set; }
    public event Action OnItemSelected;
    public void SetItemValue(Item item)
    {
        CurrentItem = item;
        NotifyStateChanged();
    }

    private void NotifyStateChanged() => OnItemSelected?.Invoke();
}

protected override void OnInitialized()
{
    ItemState.OnItemSelected += StateHasChanged;
}

在Item组件中,我正在使用其他组件并将Item本身作为参数传递,例如: <ItemHistory Itemmodel="@Item"/> 但是,在选择其他项目时,ItemHIstory组件不会刷新。 始终显示一个选定项目的历史记录。

问题出在哪里?

解决方法

答案是使用 StateContainer,因此所有组件都可以访问属性。 https://docs.microsoft.com/en-us/aspnet/core/blazor/state-management?view=aspnetcore-5.0&pivots=webassembly

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。