- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用 FormArrays 来处理可变长度的对象数组。虽然我当前的实现大部分都有效,但在验证方面我遇到了一个问题,因为对我的 FormArray 所做的任何更改都不会传播到它的“父”FormGroup...或者至少不会自动传播 FormGroup 的值可以 通过更改由所述 FormGroup 管理的另一个控件的值来更新。
在这一点上,我无法判断我的实现是否有问题,或者我是否期待一些我不应该期待的事情......无论最后“问题”是什么,我都会很乐意接受此时的任何输入。
Plunker 链接:https://plnkr.co/edit/PLslyJo1YOszGwTpujyx(Angular版本为2.0.1)
Plunker 中 app.ts 顶部的评论详细说明了重现问题的步骤(或者无论如何对我来说是什么问题)。
由于 SO 在链接到 Plunker 时需要一些代码,因此这里是与 FormGroup 和 FormArray 的定义有关的行
this.form = this.fb.group({
"size":[0, Validators.required],
"someArray": this.fb.array(this.initFormArray(0), Validators.required),
"someOtherField":[null]
});
initFormArray(size:number):FormGroup[]{
let newFormArray:FormGroup[] = [] ;
for(let i = 0 ; i < size ; i++){
newFormArray.push(this.fb.group({
fieldA: [null, Validators.required],
fieldB: [null, Validators.required]
}));
}
return newFormArray;
}
updateFormArray(value:string){
let newSize:number = parseInt(value) ;
if(newSize >= 0){
this.form.controls["someArray"] = this.fb.array(this.initFormArray(newSize))
this.form.updateValueAndValidity();
}
}
这在 Plunker 中有说明,但我不妨在这里提一下,订阅 FormArray 的 valueChanges 似乎没有帮助(或者我没有在我的订阅中做正确的事情):
this.form.controls['someArray'].valueChanges.subscribe((data) => this.form.updateValueAndValidity());
感谢任何插话的人:)
编辑(2016 年 10 月 11 日):使用 valueChanges
Hook 让我几乎可以解决问题,但解决方案并不令人满意。出于这个原因,我正在编辑而不是回答我自己的问题,但如果任何 mod 认为这是一个有效的结论,请务必做你认为足够的事情。
至于我的“解决方案”:不是在 FormArray 或根 FormGroup 级别订阅 valueChanges
,我几乎可以通过订阅 valueChanges
observable 来实现我想要的组成 FormArray 的每个 FormGroup:
initFormArray(size:number):FormGroup[]{
let newFormArray:FormGroup[] = [] ;
for(let i = 0 ; i < size ; i++){
let formGroup = this.fb.group({
fieldA: [null, Validators.required],
fieldB: [null, Validators.required]
}) ;
formGroup.valueChanges.subscribe((data) => this.form.updateValueAndValidity());
newFormArray.push(formGroup);
}
return newFormArray;
通过这样做,当 FormArray 被修改时,根 FormGroup 会被更新,但有一个滞后。例如,如果我在字段 A 中输入“123”,则根 FormGroup 值包含 "fieldA":"12"
。
因此我的“解决方案”并不令人满意:通过在订阅中添加一个虚拟的 setTimeout,根 FormGroup 完全按照我想要的方式更新......除了理想情况下不需要 setTimeout。
formGroup.valueChanges.subscribe((data) => setTimeout(()=>this.form.updateValueAndValidity(), 1);
有没有什么方法可以在不诉诸 setTimeout 的情况下进行管理?
更新的 Plunker:https://plnkr.co/edit/7mbTNPHjRhlU3ostf3av
最佳答案
我试了一下你的plunker,发现了问题
当您分配新的 FormArray
时更改它的大小后,您单独分配了它,没有将它与父项正确关联 FormGourp
.
使用 this.form.controls[<controlName>] = new FormControl/ FormArray/ FormGroup;
不适用 parent
新控件的属性。
这就是为什么在更新其中一个父字段时“刷新”整个表单值之前,这些值不会传播到父字段的原因。
你可以在plunker中看到, 我加了一些 console.log
是为了让你更好地理解。
我还添加了正确的方法(在我看来)来替换 someArray
的值FormArray.
使用 official documentation帮助很大。
希望对你有帮助
关于Angular2 react 形式 : syncing FormArray with parent FormGroup,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39900647/
如果我需要选择第 10 个父级,是否有更简洁的方法,然后重复 .parent() 10 次? $('#element_id').parent().parent().parent().parent().
从 angularJS 指南中的“如何创建通信指令”开始,https://docs.angularjs.org/guide/directive , 我正在尝试使用该布局来制作可导航的表单。 问题在于指
我有一个 jQuery 函数,需要获取元素父元素的位置。 它看起来像: function show(e) { //debugger; var nextTab
我正在尝试修复这个难看的代码。 RadGrid gv = (RadGrid) (((Control) e.CommandSource).Parent.Parent.Parent.Parent.Pare
我有一个 A 标签,可以触发它的曾曾曾祖 parent 的动画。以下所有方法都可以,但哪一个最有效,为什么? $(this).parent().parent().parent().parent().p
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
我在尝试定位绝对定位的 div 时遇到了一些问题。我猜它的工作方式应该是这样,但是我希望它与父对象的父对象而不是父对象一起使用,因为我有一个下拉列表,当我希望它像第一个一样保持在顶部时,它会跟随父对象
我正在做一些非常基本的 jQuery 东西,真正开始,我经常通过做类似的事情来向上导航 dom $(this).parent().parent().addClass('hello'); 我只是想知道是
此 HTML 结构有一个 div#page,其中当前页面内容将通过 Ajax 加载。内容始终由 section 标记组成,这些标记可以具有动态高度(相对于浏览器的百分比)或静态高度(以像素为单位)。
在 javascript 中是否有一种简单的方法来定位父对象的父对象? 我使用 this.parentNode 作为函数的元素来选择父节点,我尝试了 this.parent.parentNode 和
当遍历 pager.Pages 对象的 foreach 循环时,$data 是 self(正如预期的那样)。但是,$parent 应该是寻呼机对象,但它返回的是 WaterQualityResultV
在架构中,我想根据父级的 sibling 调整架构。 例如:如果 toggleMonday 为真,那么 weekdays -> monday 应该有一个特定的验证模式。 现在下面的例子有效。但是,它非
我想要完成的是,当用户将焦点放在文本框上时,其中的字段集将添加一个类“active_fieldset”,以便提供用户在表单中的位置的良好视觉提示。使用以下 javascript,它确实会影响父字段集,
我创建了这个函数来保存我的taches sauverTache(tache:Tache){ this.editionEnCours = true; tache.estReelle =
所以..这是我的问题..我有以下代码(示例): var GameObject = function (posX, posY, width, height) { this.posX = posX;
所以,我是 jQuery 的新手,我正在尝试更改关于函数触发器的 2 个级别的 div: 这是我的第一次尝试:我尝试找到最接近的“.node”,它是所有其他 div 的父级并编辑子 div。 fun
我想了解为什么使用 ng-repeat在repeat 的item 上有某个controller,那个item 的parent 和那个item 的祖父是同一个controller。我期待祖父成为父 Co
我想从我的组件 Controller 之一将 jsonModel 设置为我的 SAPUI5 组件。在组件内,我使用应用程序或 splitapp。 我想避免通过 ID 获取元素。从组件内的某个位置获取层
我不确定如何在标题上准确地表达出来,因为问题在我的场景中太具体了,但无论如何基本上我有两个类似于下面的外部类: class Config { public level: number = 1;
在我正在编写的这个脚本中,我发现自己连续使用 .parent() 最多七次来获取元素。虽然这有效,但似乎可以/应该有一种更简单的方法来完成我不知道的这个/功能。除了更多元素上更具体的类/ID 之外,还
我是一名优秀的程序员,十分优秀!