- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
[作为一个新手,试图将其放入 plnkr,但不能;将@angular/forms 添加到 json 时出现问题。]
目的:解决我在 FormBuilder 中完成所有工作所需知道的事情HTML:
<input type="text"
formControlName="bucket"
value="A"
[(ngModel)]="AllData.bucket" />
// added to button to test: [disabled]="this.myTestForm.invalid || this.myTestForm.pristine"
<div><button
type="submit">submit</button></div>
</form>
<div *ngIf="result.length > 0 ">{{result}}</div>
<div *ngIf="myTestForm.errors === true ">ERRORS FOUND</div>
运行应用程序:显示下面 ts 中的表单生成器正确初始化输入字段,如果我添加上面注释的 [disabled] 表达式,它会正确禁用按钮。
这是 ts: 从'@angular/core'导入{Component,OnInit}; 从 '@angular/forms' 导入 {Validators, FormBuilder, FormGroup};
@Component({
selector: 'app-home',
templateUrl: './home.component.html',
styleUrls: ['./home.component.css']
})
export class HomeComponent implements OnInit {
myTestForm: FormGroup;
result: string;
AllData = { //// wired to ngModel
bucket: '12'
}
constructor(private fb: FormBuilder) {
this.result = '';
}
ngOnInit() {
this.myTestForm = this.fb.group({
bucket: ['starting value', [Validators.required, Validators.minLength(5)]]
<-- ngModel bucket above overrides this init value as expected -->
});
}
onSubmit(value: any) { // ways to show results
this.result = this.AllData.bucket;
// OR //
this.result = this.myTestForm.controls['bucket'].value;
// OR //
this.result = this.myTestForm.get('bucket').value;
}
}
应用程序按预期在输入字段中初始化为“12”。无论我在按下提交按钮之前在文本框中输入了什么,devTools 始终将 myTestForm 的“错误”属性显示为未定义。
我希望错误具有某种基于正在发生的错误类型的字符串。
此外,我在网上搜索了在错误发生后立即捕获无效字段的方法(当然是 !pristine 字段),但我什么也做不了。
任何帮助将不胜感激。
提前致谢,查克
最佳答案
我创建了一个小的 demo就您的方法提出建议
当您使用响应式表单方法时,不要使用 [(ngModel)]
,因为 ngModel
将优先于 formControl
并将其值设置为控件,而不考虑您已初始化的 formcontrol 的
值。
<form [formGroup]="myTestForm" >
<input type="text"
formControlName="bucket"
value="A" />
<div><button
[disabled]="myTestForm.invalid || myTestForm.pristine"
type="submit" >submit</button></div>
</form>
要检查表单错误,请在控件
上使用hasError()
<div *ngIf="myTestForm.get('bucket').hasError('required')">Input is required</div>
<div *ngIf="myTestForm.get('bucket').hasError('minlength')">Min length should be 5</div>
关于javascript - 无效输入时 Angular 5 FormBuilder 错误未定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51179447/
此时,程序显示两种选择并打印一条语句,表明用户赢了、计算机赢了还是平局。继续玩直到用户选择停止,然后打印用户赢的次数,损失, 和关系. import java.util.Scanner; import
我想在 d3.js 中制作一个条形图,每个项目或行都有正条和负条,如下所示: 它有点像谷歌金融“行业摘要”图表(http://google.com/finance) 任何人都可以指出我这种图表的 d3
尝试根据 GF 和 GA 创建一个新列“Results”。想知道如何通过定义函数和条件语句来做到这一点。以下是我对一行的初步尝试,但无法弄清楚如何将其应用于所有行,非常感谢您的帮助! 日期地点对手GF
我对 Java 还很陌生,并且有一项任务被困住了。我相信我的 boolean 函数是正确的,但是我不知道在主函数中要写什么。 这是作业: 编写一个公共(public)函数(静态方法)winner(in
使用掷骰子游戏中的 10,000 次模拟来计算获胜概率 (wins/(wins + Loss))。下面是双骰子游戏的方法: public class CrapsGame { public st
我是一名优秀的程序员,十分优秀!