使用 Blazor 单击提交后清除输入字段

And*_*ahl 4 blazor blazor-server-side

我想知道是否有人知道如何在按下保存按钮“已提交”后清除所有输入字段?当我返回页面时,我的价值观仍然存在。

这是我正在使用的代码。

@page "/testform"
@inject BlazorApp6.Data.Person person
@inject BlazorApp6.DBContext.ValidationTestContext Context
@inject BlazorApp6.Interface.INterface Manager

<EditForm Model="@person" OnValidSubmit="@CreatePerson">
        <DataAnnotationsValidator />
        <ValidationSummary />
        <div class="form-group">
            <label for="Name">Name</label>
            <InputText @bind-Value=Person.Name class="form-control" id="Name" />
            <ValidationMessage For=@(() => Person.Name) />
        </div>
        <div class="form-group">
            <label for="Age">Age</label>
            <InputNumber @bind-Value=Person.Age class="form-control" id="Age" />
            <ValidationMessage For=@(() => Person.Age) />
        </div>
        <input type="submit" class="btn btn-primary" value="Save" />
    </EditForm>

@code {



    protected override async Task OnInitializedAsync()
    {
        person.OnChange += StateHasChanged;
    }

    private void CreatePerson()
    {

        Manager.Create(person);
        
       
    }

}
Run Code Online (Sandbox Code Playgroud)

Hen*_*man 9

重置所有值。最简单的方法:

private void CreatePerson()
{
    Manager.Create(person);
    person = new Person();            
}
Run Code Online (Sandbox Code Playgroud)

并且您不应该需要 StateHasChanged:

protected override async Task OnInitializedAsync()
{
    // person.OnChange += StateHasChanged;
}
Run Code Online (Sandbox Code Playgroud)

否则你必须-=+=周围的事件new Person()