Dea*_*ool 2 javascript forms angular
我正在制作一个简单的模板驱动表单,其中带有“电子邮件验证”(不是通过响应表单)。因此,必需的minlength和maxlength都可以正常工作。但是,当我尝试使电子邮件有效时,它会失败。有人可以帮我吗?
abc.component.html
<form #customForm="ngForm" (ngSubmit)="alpha(customForm)">
<input type="text" name="firstName" ngModel #firstName ="ngModel" required minlength="3" maxlength="10"><br/>
<div *ngIf="firstName.touched">
<p *ngIf="firstName.errors?.required">First Name is Required!!!</p>
<p *ngIf="firstName.errors?.minlength">First Name minimum 3 characters are required!!!</p>
<p *ngIf="firstName.errors?.maxlength">First Name max length is 10!!!</p>
</div>
<input type="email" name="email" ngModel #email="ngModel" required><br/>
<div *ngIf="email.touched">
<p *ngIf="email.errors?.required">Email is a required field!</p>
<p *ngIf="email.errors?.email">This is not a valid Email!!!</p>
</div>
<button type="submit" [disabled]="customForm.invalid">Submit</button>
</form>
Run Code Online (Sandbox Code Playgroud)
注意:虽然正在进行电子邮件的必要验证,但是由于输入的模式或数据不正确,因此电子邮件验证div中的第二次验证必须给出错误。
结果:(电子邮件有效,其模式未自动给出错误)
您可以email
在电子邮件输入中添加一个属性。但这不会使它失效,对于xxx@xxx
我认为在您的情况下不是有效电子邮件的某种模式。
我建议您pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$"
改用。然后,在显示错误消息的地方,应该检查一下email.errors?.pattern
。
试试看:
<input
type="email"
name="email"
ngModel
#email="ngModel"
pattern="[a-z0-9._%+-]+@[a-z0-9.-]+\.[a-z]{2,4}$"
required>
<br/>
<div *ngIf="email.touched">
<p *ngIf="email.errors?.required">Email is a required field!</p>
<p *ngIf="email.errors?.pattern">This is not a valid Email!!!</p>
</div>
Run Code Online (Sandbox Code Playgroud)
在此示例StackBlitz上尝试两种方法,并使用更适合您的方法。
替换此行
<input type="email" name="email" ngModel #email="ngModel" required>
Run Code Online (Sandbox Code Playgroud)
与
<input type="email" name="email" ngModel #email="ngModel" required email>// add email attribute
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2185 次 |
最近记录: |