我有一个角度应用程序,我在通过ReactiveForms进行表单验证时遇到了一些问题,我遇到以下错误:
ng投放错误:
src / app / pages / contact / contact.component.ts(48,32):错误TS2339: 类型“ FormGroup”上不存在属性“ assunto”。 src / app / pages / contact / contact.component.ts(50,57):错误TS2339: 类型“ FormGroup”上不存在属性“ assunto”。 src / app / pages / contact / contact.component.ts(51,30):错误TS2339: 类型“ FormGroup”上不存在属性“ nome”。 src / app / pages / contact / contact.component.ts(52,33):错误TS2339: 类型“ FormGroup”上不存在属性“ empresa”。 src / app / pages / contact / contact.component.ts(53,32):错误TS2339: 类型“ FormGroup”上不存在属性“ email”。 src / app / pages / contact / contact.component.ts(54,34):错误TS2339: 属性“ telefone”在“ FormGroup”类型上不存在。
contact.component.html
<form class="col-s4 dados-form" [formGroup]="dadosForm">
<mat-form-field style="width:100%" class="full-width">
<input matInput placeholder="Nome" formControlName="nome" required>
<mat-error *ngIf="dadosForm.get('nome').dirty || dadosForm.get('nome').touched">
O campo nome deve ser preenchido</mat-error>
</mat-form-field> <br>
<mat-form-field style="width:100%" class="full-width">
<input matInput placeholder="Empresa" formControlName="empresa" required>
<mat-error
*ngIf="dadosForm.get('empresa').dirty || dadosForm.get('empresa').touched">
O campo empresa deve ser preenchido</mat-error>
</mat-form-field> <br>
<mat-form-field style="width:100%" class="full-width">
<input matInput placeholder="E-Mail" formControlName="email" required>
<mat-error
*ngIf="dadosForm.get('email').dirty || dadosForm.get('email').touched">
{{getMailErrorMessage()}}</mat-error>
</mat-form-field> <br>
<mat-form-field style="width:100%" class="full-width">
<input matInput maxlength="15" id="phoneInput" formControlName="telefone" [mask]="phoneMask" placeholder="Telefone para Contato" required />
<mat-error
*ngIf="dadosForm.get('telefone').dirty || dadosForm.get('telefone').touched">
O campo telefone deve ser preenchido</mat-error>
</mat-form-field> <br>
<mat-form-field style="width:100%" class="full-width">
<mat-label>Produto Desejado</mat-label>
<mat-select matInput formControlName="assunto" required>
<mat-optgroup *ngFor="let categoria of produtos" [label]="categoria.key">
<mat-option *ngFor="let produto of categoria.value" [value]="produto">
{{produto}}
</mat-option>
</mat-optgroup>
</mat-select>
<mat-error
*ngIf="dadosForm.get('assunto').dirty || dadosForm.get('assunto').touched">
O campo assunto deve ser preenchido</mat-error>
</mat-form-field><br>
<mat-form-field style="width:100%" class="full-width">
<textarea matInput placeholder="Mensagem" formControlName="mensagem" required></textarea>
<mat-error
*ngIf="dadosForm.get('mensagem').dirty || dadosForm.get('mensagem').touched">
O campo mensagem deve ser preenchido</mat-error>
</mat-form-field><br>
<div class="form-buttons">
<button mat-button mat-raised-button id="submitButton" [disabled]="!dadosForm.valid" matTooltip="" color="primary" (click)="sendMail(mensagem)">Enviar</button>
</div>
</form>
contact.component.ts
dadosForm = new FormGroup({
nome: new FormControl('', [Validators.required]),
empresa: new FormControl('', [Validators.required]),
email: new FormControl('', [Validators.required, Validators.email]),
telefone: new FormControl('', [Validators.required]),
assunto: new FormControl('', [Validators.required]),
mensagem: new FormControl('', [Validators.required])
});
答案 0 :(得分:0)
使用表单生成器FormBuilder
进行验证
首先导入这些依赖项
import { FormGroup, FormBuilder, Validators } from '@angular/forms';
为表单组创建变量
formGroupName: FormGroup;
constructor(private _formBuilder: FormBuilder) { }
使用ngOnInit
方法设置验证代码
this.formGroupName = this._formBuilder.group({
nome: ['', Validators.required],
empresa: ['', Validators.required],
email: ['', [Validators.required, Validators.email]],
telefone: ['', Validators.required],
assunto: ['', Validators.required],
mensagem: ['', Validators.required]
});
尝试一下。
答案 1 :(得分:0)
<div *ngIf="f.name.invalid && f.name.touched">
<small class="text-danger" *ngIf="f.name.errors?.required">Please enter the name!</small>
</div>
在 ts 文件中
get f() { return this.form.controls; }
答案 2 :(得分:0)
我刚收到那个错误,我就这样做了,例如,在你的第一个输入中:
<mat-error *ngIf="dadosForm.get('nome').dirty || dadosForm.get('nome').touched">O campo nome deve ser preenchido</mat-error>
只需在 *ngIf
中更改验证:
<mat-error *ngIf="dadosForm.get('nome').invalid && (dadosForm.get('nome').dirty || dadosForm.get('nome').touched)">O campo nome deve ser preenchido</mat-error>
我使用与您相同的输入模板的 Angular 10+,我没有使用 dirty
和 touched
,因此,对于唯一验证,您可以只使用 dadosForm.invalid
在 *ngIf
内并获取您正在验证的唯一消息错误。
等效:
<mat-error *ngIf="dadosForm.get('nome').invalid">O campo nome deve ser preenchido</mat-error>
另一个等价物:
<mat-error *ngIf="dadosForm.invalid">O campo nome deve ser preenchido</mat-error>