【问题标题】:Blazor webassembly, state management. Refresh child componentsBlazor webassembly,状态管理。刷新子组件
【发布时间】:2021-02-17 05:43:34
【问题描述】:

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

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 组件在选择不同的项目时不会刷新。 始终显示第一个选定项目的历史记录。

问题出在哪里?

【问题讨论】:

    标签: state-management blazor-webassembly blazor-component


    【解决方案1】:

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

    【讨论】:

      猜你喜欢
      • 2021-12-25
      • 1970-01-01
      • 1970-01-01
      • 2020-12-13
      • 2019-11-15
      • 2020-12-13
      • 2020-12-20
      • 1970-01-01
      • 2021-08-02
      相关资源
      最近更新 更多