gpt4 book ai didi

javascript - 仅从 angular2 表单中获取已更改的数据

转载 作者:太空狗 更新时间:2023-10-29 17:57:52 26 4
gpt4 key购买 nike

嘿。我有一个基本的 angular2 形式,其中有嵌套对象。我想做的是我只想获取那些脏的字段。我在获取深层嵌套对象的值时遇到问题。 .这是我的演示http://plnkr.co/edit/gzT4mVWglHrFziRayHtK?p=preview ,此处在 Contacts 字段中所做的更改将进入主对象...

{
"addressinfo": {
"Line1": "",
"Line2": ""
},
"firstname": "",
"lastname": "",
"Contacts": {
"Phone1": {
"Type": "",
"Number": ""
}
}
}

如果我更改数字字段并提交表单,那么我将以这种方式获得响应对象...

{
"Contacts": {},
"Phone1": {
"Number": ""
}
}

由于 Number 字段已更改,我希望以这种方式输出

{
"Contacts": {
"Phone1": {
"Number": ""
}
},
}

有人帮我只获取正确对象格式的更改数据...谢谢

最佳答案

您是否尝试过在调试 session 中单步执行代码(例如使用 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 再次查看控制组。这些调用的结果被收集起来,放入一个对象中,并在我们完成后返回。
  • 在控件的情况下:我们可以收集值并返回它。

关于javascript - 仅从 angular2 表单中获取已更改的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37626539/

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