如何保留Blazor 应用组件中的数据?

Zhi Lv - MSFT 32,831 信誉分 Microsoft 供应商
2024-03-28T07:19:28.9533333+00:00

大家好。

在 Blazor 应用程序的默认模板中,单击按钮时,计数变量将增加 1。但是当导航到其他组件然后返回计数器组件时,计数值将重置为 0,我需要在此默认模板中做哪些更改来修复此问题,以便在返回时保留值。

谢谢。

注意: 该问题整理于:Blazor default template application issue

Blazor
Blazor
一个免费的开源 Web 框架,使开发人员能够使用 Microsoft 开发的 C# 和 HTML 创建 Web 应用。
26 个问题
0 个注释 无注释
{count} 票

接受的答案
  1. XuDong Peng-MSFT 10,931 信誉分 Microsoft 供应商
    2024-03-28T08:57:50.87+00:00

    你好,

    可以使用内存中状态容器服务浏览器存储利用ASP.NET Core 数据保护)用于 localStorage and sessionStorage来保留数据。

    例如,使用内存中状态容器服务:

    1. 在 Models 文件夹中创建 StateContainer 类(此示例是 Blazor WebAssembly 应用):
    public class StateContainer
        {
            private int? savedCounter;
     
            public int Counter
            {
                get => savedCounter ?? 0;
                set
                {
                    savedCounter = value;
                    NotifyStateChanged();
                }
            }
     
            public event Action? OnChange;
     
            private void NotifyStateChanged() => OnChange?.Invoke();
        }
    
    1. 在 program.cs 文件中注册 StateContainer 类:
    builder.Services.AddSingleton<StateContainer>();
    
    1. 在计数器组件(Counter.Razor),请使用以下代码:
    @page "/counter"
    
    @using BlazorWebAssemblyApp2.Models;
    @implements IDisposable
    @inject StateContainer StateContainer
    
    <PageTitle>Counter</PageTitle>
    <h1>Counter</h1>
     
    <p role="status">Current count: @currentCount</p>
     
    <button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
     
    @code {
        private int currentCount = 0;
        protected override void OnInitialized()
        {
            StateContainer.OnChange += StateHasChanged;
     
            currentCount = StateContainer.Counter;
        }
        private void IncrementCount()
        {
            currentCount++;
            StateContainer.Counter = currentCount;
        }
        public void Dispose()
        {
            StateContainer.OnChange -= StateHasChanged;
        }
    }
    

    结果如下: image1

    如果应用程序是 Blazor 服务器应用程序,也可以使用上述代码,或者参考以下代码使用 ProtectedBrowserStorage 保留数据,也会得到相同的结果。

    @page "/counter"
     
    @using Microsoft.AspNetCore.Components.Server.ProtectedBrowserStorage
    @inject ProtectedSessionStorage ProtectedSessionStore
    <h1>Counter</h1>
     
    <p>Current count: @currentCount</p>
     
    <button class="btn btn-primary" @onclick="IncrementCount">Click me</button>
     
    @code {
        private int currentCount = 0;
     
        protected override async Task OnInitializedAsync()
        {
            var result = await ProtectedSessionStore.GetAsync<int>("count");
            currentCount = result.Success ? result.Value : 0;
        }
     
        private async void IncrementCount()
        {
            currentCount++;
            await ProtectedSessionStore.SetAsync("count", currentCount);
        }
    }
    

    有关详细信息,请参阅 ASP.NET Core Blazor 状态管理


    如果答案是正确的,请点击“接受答案”并点赞。 如果您对此答案还有其他疑问,请点击“评论”。 注意:如果您想接收相关电子邮件,请按照我们的文档中的步骤启用电子邮件通知 此线程的通知。

    0 个注释 无注释

0 个其他答案

排序依据: 非常有帮助

你的答案

问题作者可以将答案标记为“接受的答案”,这有助于用户了解已解决作者问题的答案。