gpt4 book ai didi

javascript - Angular 4 为无效的电子邮件输入设置 ng-valid

转载 作者:行者123 更新时间:2023-11-28 00:53:19 25 4
gpt4 key购买 nike

Angular 4 模板驱动验证失败。这是一个已知问题,还是我的错误?

HTML:

<div class="form-group">
<label for="email">Email</label>
<input type="email" class="form-control" id="email" required
[(ngModel)]="model.email" name="email" #email="ngModel" #spy>

<div>TODO remove: {{spy.className}}</div>
<div [hidden]="email.valid || email.pristine" class="alert alert-danger">
Valid email is required
</div>
</div>

组件类有属性: model = new SignupModel('','','','');

CSS:

input:invalid:not(.ng-pristine) {
border-left: 5px solid #a94442; /* red */
}
input:valid:not(.ng-pristine) {
border-left: 5px solid #42A948; /* green */
}

当页面首次加载时,您可以看到电子邮件类名:form-control ng-untouched ng-pristine ng-invalid由于 email.pristine === true,警报消息被隐藏

当用户开始输入“aa”时,类名会发生变化:form-control ng-dirty ng-valid ng-touched现在由于 email.valid === true 消息被隐藏了但是,由于“aa”不是有效的电子邮件,左边框通过 css 显示为红色。

当 css 正确地将输入解释为无效时,为什么 Angular 认为 email.valid 为真并设置 ng-valid 类?

当您删除“aa”时,样式类确实会更改为 ng-invalid,从而正确解释“必需”属性。

最佳答案

解决方案是向输入标签添加额外的“电子邮件”属性:

<input type="email" class="form-control" id="email" required email 
[(ngModel)]="model.email" name="email" #email="ngModel">

关于javascript - Angular 4 为无效的电子邮件输入设置 ng-valid,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46080863/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com