Hie。我有一个基本的angular2形式,我有嵌套的对象。我想要做的是我只想得到那些脏的字段。我面临着获得深层嵌套对象的价值的问题。 。这是我的演示版http://plnkr.co/edit/gzT4mVWglHrFziRayHtK?p=preview,此处在“联系人”字段中完成的更改将出现在主要对象...
中{
"addressinfo": {
"Line1": "",
"Line2": ""
},
"firstname": "",
"lastname": "",
"Contacts": {
"Phone1": {
"Type": "",
"Number": ""
}
}
}
如果我更改数字字段并提交表单,那么我将以这种方式获取响应对象...
{
"Contacts": {},
"Phone1": {
"Number": ""
}
}
由于Number字段已被更改,我希望输出以这种方式
{
"Contacts": {
"Phone1": {
"Number": ""
}
},
}
有人帮助我只使用正确的对象格式获取更改的数据...谢谢
答案 0 :(得分:2)
您是否尝试在调试会话中单步执行代码(例如,使用debugger语句)?在检查您的Contacts
控制组时,它会将此名称作为新对象推送到ResultObject
并再次开始执行recursivelyIterateProperties(jsonObject,ResultObject,activeProperty)
,并使用以下参数:
jsonObject = {Phone1: ControlGroup},
ResultObject = {Contacts: {}},
activeProperty = 'Contacts'
问题是,Phone1
又是一个控制组,因此您的=== 'object'
代码会再次执行,将新的Phone1
对象直接推送到ResultObject
。换句话说,您的代码不能很好地处理嵌套控件组。
我冒昧地将您的代码重写为一个有效的示例:Plunker。
为清楚起见,初始控制组的迭代已从值集合中分离出来。我们首先遍历所有控件:
iterateOverControls(controls, resultObject): any {
var resultObject = {};
// Iterate over controls and controlgroups
for ( var control in controls ) {
var result = {}
// Only look into dirty controls
if ( controls.hasOwnProperty(control) && !controls[control].pristine ) {
result[control] = this.retrieveValuesForControl(controls[control]);
// Once we have collected the changes, add them to the result object
for ( var key in result ) {
if ( result.hasOwnProperty(key) ) {
resultObject[key] = result[key];
}
}
}
}
return resultObject;
}
对于我们遇到的每个控件,我们尝试通过调用retrieveValuesForControl
来收集其值。此方法需要我们当前正在查看的控件作为参数。
retrieveValuesForControl(control): any {
// Only check dirty objects
if ( control.pristine ) {
return;
}
var values;
if ( typeof(control.value) === 'object' && control.controls ) {
// The current control is a control group, so we need to look deeper
values = {};
for ( var item in control.controls ) {
// We retrieve values for this control again (recursively)
values[item] = this.retrieveValuesForControl(control.controls[item]);
}
} else if ( !control.pristine) {
// We have a control, so copy the value
values = control.value;
}
// Return our collected values (either a plain value or object of values)
return values;
}
在这种方法中,我们首先检查我们正在查看的控件是否脏。如果它是原始的,我们直接返回。接下来,我们检查我们是否正在查看对照组或对照组。
iterateOverControls
来再次查看控制组。收集这些调用的结果,将其放入一个对象中,并在完成后返回。 答案 1 :(得分:0)
我觉得你无法正确找到它们。
tab
这是您可以找到数字和类型的确切方式。我没有发现你的掠夺者有任何问题。
答案 2 :(得分:0)
您也可以订阅
this.myForm.valueChanges.subscribe(...)
以这种方式收集更改的值。