gpt4 book ai didi

json - 如何在angular2中以数组形式显示嵌套数组数据?

转载 作者:行者123 更新时间:2023-12-01 01:43:30 24 4
gpt4 key购买 nike

我已经在 angular2 项目中实现了 FormGroup 来渲染表单,并且我已经使用 formArray 来获取嵌套数组数据

form.component.html

<div class="col-md-12" formArrayName="social_profiles">
<div *ngFor="let social of resumeForm.controls.social_profiles.controls; let i=index" class="panel panel-default m-t-10">
<div class="panel-heading" style="min-height: 30px;">
<span class="glyphicon glyphicon-remove pull-right" *ngIf="resumeForm.controls.social_profiles.controls.length > 1" (click)="removeSocialProfiles(i)"></span>
</div>
<div class="panel-body" [formGroupName]="i">
<social-profile [group]="resumeForm.controls.social_profiles.controls[i]"></social-profile>
</div>
</div>
</div>

form.component.ts

export class FormComponent implements OnInit {
public resumeForm: FormGroup;

constructor(private formBuilder: FormBuilder) {}

ngOnInit() {
this.resumeForm = this.formBuilder.group({
name: ['', Validators.required],
label: ['',],
email: [''],
phone: [''],
social_profiles: this.formBuilder.array([])
});

this.addSocialProfiles();
}

initSocialProfiles() {
return this.formBuilder.group({
network: [''],
url: ['']
});
}

addSocialProfiles() {
const control = <FormArray>this.resumeForm.controls['social_profiles'];
const addrCtrl = this.initSocialProfiles();
control.push(addrCtrl);
}

removeSocialProfiles(i: number) {
const control = <FormArray>this.resumeForm.controls['social_profiles'];
control.removeAt(i);
}
}

其中social-profile是数组的子表单

social-profile.component.html

<div [formGroup]="socialForm">
<div class="col-md-6">
<input type="text" class="form-control" placeholder="Enter Network" formControlName="network">
</div>
<div class="col-md-6">
<input type="text" class="form-control" placeholder="Enter Network URL" formControlName="url">
</div>
</div>

social-profile.component.ts

export class SocialProfileComponent {
@Input('group')
public socialForm: FormGroup;
}

从服务回调中获取 JSON

{
"basics_info": {
"name": "Joh Doe",
"label": "Programmer",
"Social_profiles": [{
"network": "Twitter",
"url": "https://www.twitter.com/kumarrishikesh12"
}, {
"network": "Facebook",
"url": "https://www.facebook.com/kumarrishikesh12"
}]
}
}

添加数据表单工作完美,但如何在页面 init 的编辑时间以表单形式显示现有的嵌套 json 数组(从 api 获取)?如下图所示

enter image description here

最佳答案

这里假设您已经从对象 basics_info 中提取了内容,即:

并将 JSON 分配给变量 data,这样您最终会得到 data 的内容:

{
"name": "Joh Doe",
"label": "Programmer",
"Social_profiles": [{
"network": "Twitter",
"url": "https://www.twitter.com/kumarrishikesh12"
}, {
"network": "Facebook",
"url": "https://www.facebook.com/kumarrishikesh12"
}]
}

然后让我们修补这些值。您可以在收到数据后收到 JSON(或构建表单)后修补这些值。在这里,我在构建表单后修补值。

为了澄清起见,我在下面调用 patchValues 中的另一个方法,它实际上设置了值。

patchValues() {
const control = <FormArray>this.resumeForm.controls['social_profiles'];
this.data.Social_profiles.forEach(x => { // iterate the array
control.push(this.patch(x.network, x.url)) // push values
});
}

patch(network, url) {
return this.fb.group({
network: [network],
url: [url]
});
}

child 应该能很好地捕捉到这些变化。这是给您的演示,变量不同,因为我使用了现有的表单。但逻辑是完全一样的。

Plunker

关于json - 如何在angular2中以数组形式显示嵌套数组数据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43291858/

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