- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
正如我之前在 question 中询问的那样
我想创建一个嵌套表单,其中父级与 child 的 formControlNames
假设我们有一个组件 componentA.component.ts
@Component({
selector: 'common-a',
template: `
<div [formGroup]="parentForm">
<div class="form-group">
<label>Common A[1]</label>
<div >
<input type="text" formControlName="valueA1">
<small>Description 1</small>
</div>
<div class="form-group">
<label>Common A[2]</label>
<div >
<input type="text" formControlName="valueA2">
<small>Description 2</small>
</div>
</div>
`
})
export class ComponentA implements OnInit{
@Input() parentForm: FormGroup;
constructor(private _fb: FormBuilder) {
}
ngOnInit() {
this.parentForm.addControl("valueA1", new FormControl('', Validators.required));
this.parentForm.addControl("valueA2", new FormControl('', Validators.required));
}
}
和主要成分。
@Component({
selector: 'main',
template: `
<form [formGroup]="myForm" (ngSubmit)="onSubmit(myForm.value)">
<div>
<div *ngFor="let c of myForm.controls.componentA.controls; let i=index" class="form-group">
<common-a [parentForm]="c"></common-a>
</div>
<div>
<button type="submit" [disabled]="myForm.invalid">Register!</button>
<a class="button" (click)="add_component()">Add New</a>
<a class="button" (click)="delete_component()">Delete</a>
</div>
</div>
<pre>form value: <br>{{myForm.value | json}}</pre>
</form>
`
})
export class MainComponent implements OnInit{
@Input('group') public myForm: FormGroup;
add_component() {
const control = <FormArray>this.myForm.controls['componentA'];
control.push(this._fb.group({}));
}
delete_component() {
const control = <FormArray>this.myForm.controls['componentA'];
control.removeAt(this.myForm.length-1);
}
constructor(private _fb: FormBuilder) {
}
ngOnInit() {
this.myForm = this._fb.group({
componentA : this._fb.array([this._fb.group({})])
});
}
onSubmit(formValue) {
console.log(formValue);
}
}
我现在的问题是如何使用 patchValue
从服务器端点获取数据并填充表单数组的值,按需创建新的 FormGroups
,始终不可知给家长。
除了糟糕的架构之外,这种方法的问题在于我用自己的实现重写了 patchValue 方法并按需推送这些新组,因为在函数体内我知道有多少,但是 child 的 OnInit不会在函数内调用,将值留空。
var self = this;
this.formArray.patchValue = (value: {[key: string]: any}, {onlySelf, emitEvent}: {onlySelf?: boolean, emitEvent?: boolean} = {}) =>{
for(var i = 0; i < Object.keys(value).length; i++ ) {
self.add_new();
}
Object.keys(value).forEach(name => {
if (self.formArray.controls[name]) {
self.formArray.controls[name].patchValue(value[name], {onlySelf: true, emitEvent});
}
});
self.formArray.updateValueAndValidity({onlySelf, emitEvent});
}
我再次认为这是糟糕的设计。
static generate() {
return new FormGroup({
valueA1: new FormControl('', Validators.required),
valueA2: new FormControl('', Validators.required)
});
}
对于此类问题,您有任何干净的解决方案吗?
还有一个有效的 plunkr根据我之前的问题
最佳答案
动态控件的替代解决方案。
1: 注入(inject) ChangeDetectorRef
constructor(private _changeDetectorRef: ChangeDetectorRef) { }
2:覆盖补丁值
this.control = new FormArray([]);
let patchValue = this.control.patchValue;
this.control.patchValue = (value: any, options?: Object) => {
for (let i = this.control.length; i < value.length; i++) {
// Push new item
}
this._changeDetectorRef.detectChanges();
patchValue.apply(this.control, [value, options]);
};
关于FormArray 中的 Angular2 patchValue,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41464596/
我正在推送一个带有一些值的 FormArray,我需要在加载列表后在某些字段中动态设置禁用属性。我的问题是:有没有办法只使用 patchValue 来设置值和设置 disabled 属性? 我尝试过类
我有一个包含多个嵌套表单数组的响应式(Reactive)表单。在我的表单中,我可以有多个段和多个集合,问题是在从数据库获取数据时使用 patchValue() 或 setValue() 来编辑我的表单
我正在尝试使用 patchValue() 通过表单组设置输入值,但输入仍然为空,这是我的代码示例... component.html Unique User ID Store
它看起来像 Angular2 的 FormGroup.patchValue() 吗?不会将新元素插入数组。 例如这样的事情: ngOnInit() { this.form = this.for
我使用模板驱动并尝试使用 patchValue 初始化我的表单,但它不起作用。 如果我使用双向绑定(bind)来设置值 [(fooBar)] 甚至 setTimeout,我可以让它工作,但我只是想知道
正如我之前在 question 中询问的那样 我想创建一个嵌套表单,其中父级与 child 的 formControlNames 无关 假设我们有一个组件 componentA.component.t
我有这样的 Json 数据: assets/details.json { "name" : "john", "age" : 20, "address" : [{
我正在更新 blur 上的字段值,使其成为 blur 上的货币值。当我输入我的值并离开 formcontrol 时,模糊工作更新并使值 (20.00) 到 ($20.00) 或 (20.05060)
我必须知道 patchValue 方法的概念。使用补丁值方法更新表单值时,表单变脏。 // using this way setTimeout(() => { this.skillForm
示例代码如下: model={name: "D100" value: "Dying"}; for (let key in model) { if(this.divisio
我正在使用 Angular 表单生成器添加数据,其中表单有一个选择元素,其值是绑定(bind)到对象,但是当我尝试使用补丁值方法或设置值方法字段编辑表单时,除了选择正在获取提交了正确的数据,请有人纠正
我有一个使用 ControlValueAccessor 的带有子表单的表单 profile-form.component.ts form: FormGroup; this.form = this.fo
一旦像这样加载组件,我就会尝试将值修补到初始化的 FormGroup 中(其中 editForm 是 FormGroup,editInfo 是包含我想要修补到表单中的信息的 JSON): Object
在我的 Angular 7 应用程序中,我使用 react 形式的 Angular Material 组件 mat-select。 View 看起来像这样:
我正在使用表单生成器构建响应式(Reactive)表单。表单数据需要动态更新。为了实现这一目标,我创建了一个函数,该函数迭代对象中的键并使用匹配的键名称修补表单值。这在大多数情况下都有效,但是,生成的
我有一个基于 Angular 文档的动态表单,我有一个功能可以让用户加载他们保存的表单。目前我可以修补其他表单字段的值,如文本字段和单选按钮,但我不能在数组上这样做,因为它的值是一个数组。 我有以下代
我希望在用户在创建的空控件中添加值后更新 formArray。 目前,当用户选择添加一个新项目时,我会使用空值构建到 formArray 上。 buildItem(item?: any, key?:
我尝试通过选择选择框来动态呈现 cat_name。但我无法使用 patchValue 渲染 cat_name。下面是我呈现子 formArray 的代码。 通过使用更改事件选择选择框,我得到了基于值的
我在 Angular 6 中创建编辑表单。 当我加载页面时,它使用以下代码设置值: this.editFG.patchValue({ productTitle: [data.productTitl
我有一个多步骤表单,用户可以在其中来回遍历表单。我将表单数据保存在服务中,当他回来时,我使用 patchValue 将所有数据修补到表单中。我也尝试了 setValue,但表单字段未标记为脏或已触及。
我是一名优秀的程序员,十分优秀!