Angular动态表单项目迁移-'input'没有初始化程序和构造函数,TypeT|undefined的另一个错误
创始人
2024-10-24 14:01:13
0

这个问题通常发生在将 Angular 旧版代码升级到新版的过程中。原因是在旧版中,可能会在构造函数中初始化值,但在新版中,它会优先使用使用输入属性进行初始化,然后才会执行构造函数。解决方法是将输入属性值初始化放在构造函数之前,在组件中添加 ngAfterViewInit() 生命周期钩子方法。以下是示例代码:

import { AfterViewInit, Component, Input } from '@angular/core';
import { FormGroup } from '@angular/forms';

@Component({
  selector: 'app-dynamic-form',
  template: `
    
`, }) export class DynamicFormComponent implements AfterViewInit { @Input() fields: any[]; form: FormGroup; ngAfterViewInit() { // Initialize input values before the constructor is executed this.fields = this.fields || []; // Initialize the form after the input values this.form = this.createFormGroup(); } private createFormGroup() { const group = new FormGroup({}); this.fields.forEach((field) => { const control = field.required ? new FormControl(field.value || '', Validators.required) : new FormControl(field.value || ''); group.addControl(field.name, control); }); return group; } }

相关内容

热门资讯

xpoker辅助神器!智星菠萝... xpoker辅助神器!智星菠萝可以辅助吗(透视)插件-总是辅助有挂1、实时智星菠萝可以辅助吗透视辅助...
wepoker私人局透视教程!... wepoker私人局透视教程!wepoker私人局俱乐部怎么进(透视)神器-都是有挂真的是有挂wep...
拱趴大菠萝万能辅助器!wepo... 拱趴大菠萝万能辅助器!wepoker辅助器怎么弄(透视)方法-竟然专业是有挂拱趴大菠萝万能辅助器脚本...
wepoker怎么获得好牌!w... wepoker怎么获得好牌!wepoker透视app下载(透视)技巧-都是解谜真的有挂1、每一步都需...
wpk德州局怎么透视!wepo... wpk德州局怎么透视!wepoker透视有没有(透视)脚本-切实揭幕有挂1、下载好wpk德州局怎么透...
poker world辅助!w... poker world辅助!wpk辅助软件(透视)挂-一直关于有挂1、打开软件启动之后找到中间准星的...
aapoker透视怎么用!we... aapoker透视怎么用!wepoker破解器(透视)挂-一直辅助真的有挂所有人都在同一条线上,像星...
wepoker辅助器是真的吗!... wepoker辅助器是真的吗!hhpoker辅助挂是真的吗(透视)插件-一贯辅助是真的挂1.hhpo...
透视专业!德普之星辅助软件(透... 透视专业!德普之星辅助软件(透视)hh poker辅助器先试用,教程经验(的确有挂)-哔哩哔哩1、h...
hhpoker脚本!fishp... hhpoker脚本!fishpoker透视底牌(透视)方法-切实解密存在有挂1、玩家可以在fishp...