如何使用 MudBlazor 进行表单验证?

Posted

技术标签:

【中文标题】如何使用 MudBlazor 进行表单验证?【英文标题】:How can I do form validation with MudBlazor? 【发布时间】:2021-02-09 14:16:45 【问题描述】:

我用 MudBlazor 构建了一个漂亮的注册表单。

     <MudCard Class="signup-form">
        <MudCardContent>
           <form>
            <MudTextField Label="Username" />
            <MudTextField Label="Email" />
            <MudTextField Label="Password" />
            <MudTextField Label="Repeat password" />
          </form>
        </MudCardContent>
        <MudCardActions>
            <MudButton Variant="Variant.Filled" Color="Color.Primary">Sign up</MudButton>
        </MudCardActions>
    </MudCard>

但是当用户输入不充分或错误时,如何显示验证错误?在 MudBlazor 中找不到有关如何执行此操作的信息。

【问题讨论】:

【参考方案1】:

表单验证在MudBlazor Form documentation 中有详细记录。以下是使用 Blazor 内置验证机制的方法,这对于您的用例来说可能是最简单的:

<EditForm Model="@model" OnValidSubmit="OnValidSubmit">
    <DataAnnotationsValidator />
    <MudCard Class="demo-form">
        <MudCardContent>
            <MudTextField Label="Username" HelperText="Max. 8 characters" @bind-Value="model.Username" For="@(() => model.Username)" />
            <MudTextField Label="Email" @bind-Value="model.Email" For="@(() => model.Email)" />
            <MudTextField Label="Password" HelperText="Choose a strong password" @bind-Value="model.Password" For="@(() => model.Password)" InputType="InputType.Password" />
            <MudTextField Label="Password" HelperText="Repeat the password" @bind-Value="model.Password2" For="@(() => model.Password2)" InputType="InputType.Password" />
        </MudCardContent>
        <MudCardActions>
            <MudButton ButtonType="ButtonType.Submit" Variant="Variant.Filled" Color="Color.Primary" Class="demo-form-button">Register</MudButton>
        </MudCardActions>
    </MudCard>    
</EditForm>

@code 
    RegisterAccountForm model = new RegisterAccountForm();

    public class RegisterAccountForm
    
        [Required]
        [StringLength(8, ErrorMessage = "Name length can't be more than 8.")]
        public string Username  get; set; 

        [Required]
        [EmailAddress]
        public string Email  get; set; 

        [Required]
        [StringLength(30, ErrorMessage = "Password must be at least 8 characters long.", MinimumLength = 8)]
        public string Password  get; set; 

        [Required]
        [Compare(nameof(Password))]
        public string Password2  get; set; 

    

    private void OnValidSubmit(EditContext context)
    
        // register the user
    


【讨论】:

你可以在 try mudblazor 中使用上面的 sn-p:try.mudblazor.com/snippet/QkQFvFvqLdqIZuvW

以上是关于如何使用 MudBlazor 进行表单验证?的主要内容,如果未能解决你的问题,请参考以下文章

不使用 django 表单如何验证和保存表单数据

avalon的表单验证

PHP 表单

Blazor WASM - 分成多个组件 (MudBlazor)

如何在 Laravel 或其他框架中正确编写表单?

极验请在下图依次点击怎么验证不了