Angular动态表单可观察输入属性始终为null。
创始人
2024-10-24 14:01:03
0

在Angular中,动态创建的表单控件的可观察输入属性的初始值通常是null。这是因为在动态创建表单控件时,初始值可能还没有被设置。

要解决这个问题,我们可以使用Angular的值更改检测机制来处理可观察输入属性的变化。我们可以在ngOnChanges生命周期钩子中订阅可观察输入属性的变化,并在变化时更新表单控件的值。

以下是一个示例代码,展示了如何解决这个问题:

import { Component, Input, OnChanges, SimpleChanges } from '@angular/core';
import { FormControl } from '@angular/forms';
import { Observable } from 'rxjs';

@Component({
  selector: 'app-dynamic-form',
  template: `
    
  `,
  styleUrls: ['./dynamic-form.component.css']
})
export class DynamicFormComponent implements OnChanges {
  @Input() inputValue$: Observable; // 可观察输入属性
  
  inputControl: FormControl = new FormControl();

  ngOnChanges(changes: SimpleChanges) {
    if (changes.inputValue$) {
      this.inputValue$.subscribe(value => {
        this.inputControl.setValue(value); // 更新表单控件的值
      });
    }
  }
}

在上面的示例中,我们创建了一个DynamicFormComponent组件,它接收一个名为inputValue$的可观察输入属性。在ngOnChanges生命周期钩子中,我们订阅了inputValue$的变化,并在变化时使用setValue方法更新了inputControl的值。

这样,无论inputValue$的初始值是什么,它都会被正确地设置到表单控件中。

相关内容

热门资讯

透视科技!哈糖大菠萝攻略,we... 透视科技!哈糖大菠萝攻略,werplan外挂,德州教程(有挂解密);1、哈糖大菠萝攻略ai辅助优化,...
透视能赢!大菠萝手游辅助,拱趴... 透视能赢!大菠萝手游辅助,拱趴大菠萝万能挂图解,分享教程(有挂方法);小薇(透视辅助)致您一封信;亲...
透视计算!佛手在线大菠萝技巧,... 透视计算!佛手在线大菠萝技巧,红龙poker有辅助吗,详细教程(有挂方法)1、这是跨平台的佛手在线大...
透视存在!竞技联盟破解版最新版... 透视存在!竞技联盟破解版最新版,来玩app破解,解密教程(有挂解说)1、让任何用户在无需竞技联盟破解...
透视教学!fishpoker透... 透视教学!fishpoker透视,德州真人透视脚本,透明挂教程(有挂揭秘)暗藏猫腻,小编详细说明德州...
透视透视挂!德州私人局脚本,菠... 透视透视挂!德州私人局脚本,菠萝德州透视脚本,2025新版教程(有挂介绍)1、每一步都需要思考,不同...
透视数据!epoker免费透视... 透视数据!epoker免费透视脚本,竞技联盟辅助插件,AI教程(有挂攻略);1、实时epoker免费...
透视辅助!hardrock透视... 透视辅助!hardrock透视工具,菠萝辅助器免费版的特点,必赢教程(有挂攻略)1)菠萝辅助器免费版...
透视好牌!扑克之星辅助,pok... 透视好牌!扑克之星辅助,pokemmo脚本辅助下载,必备教程(有挂细节)运pokemmo脚本辅助下载...
透视有挂!智星德州辅助译码插件... 透视有挂!智星德州辅助译码插件靠谱吗,德州机器人代打脚本,介绍教程(有挂攻略)所有人都在同一条线上,...