angular8表单校验

1.app.module.ts中注入:

import { FormsModule, ReactiveFormsModule } from '@angular/forms';
@NgModule({
    declarations: [],
    imports: [
        FormsModule,
        ReactiveFormsModule
    ]
})

2.app.component.ts中注入:

import { FormGroup, FormControl, Validators } from '@angular/forms';

定义校验规则:

ngOnInit() {
    this.formData = new FormGroup({
      name: new FormControl(this.name, Validators.compose([
        Validators.required,
      ])),
      score: new FormControl(this.score, Validators.compose([
        Validators.required,
        this.scoreValueValidator
      ]))
    });
  }

  scoreValueValidator(control: FormControl): any {
    if (control.value < 0 || control.value > 100) {
      return { value: {info: '分数必须大于等于0,小于等于100'} };
    }
  }

3.app.component.html中使用:

    <form [formGroup]="formData" (ngSubmit) = "onsubmit(formData.value)">
        <div class="form-group">
            <label for="name">姓名</label>
            <em>*</em>
字符串
            <input type="text" class="form-control" [formControlName]="'name'" id="name">
            <div [hidden]="formData.get('name').valid || formData.get('name').untouched" class="small">
                <p [hidden]="!formData.hasError('required', 'threshold')">必填项</p>
            </div>
        </div>
        <div class="form-group">
            <label for="score">分数</label>
            <em>*</em>
            <input type="number" min="0" max="100" class="form-control" formControlName="score" id="score">变量
            <div [hidden]="formData.get('score').valid || formData.get('score').untouched" class="small">
                <p [hidden]="!formData.hasError('required', 'score')">必填项</p>
                <p [hidden]="!formData.hasError('value', 'score')">{{formData.getError('value', 'score')?.info}}</p>
            </div>
            <button type="submit" [disabled]="!formData.valid" class="btn btn-sm btn-primary">提交</button>
        </div>
    </form>

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

秦国

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值