Angular表单:第一个输入元素不反映FormBuilder的值
创始人
2024-10-23 10:01:16
0

该问题是由于FormBuilder在创建表单时按照FormControl的顺序来创建表单控件。当您向FormGroup中添加一个FormControl时,它将成为FormGroup的第一个FormControl。当您获取FormBuilder绑定表单的值时,它将按FormControl的顺序返回表单中的值。

要解决此问题,您可以通过添加一个名为“{formControl: '', order: 1}”的对象来设置FormControl的顺序,从而指定要显示的控件。例如:

form = this.fb.group({
  name: ['', Validators.required],
  email: ['', [Validators.required, Validators.email]],
  phone: ['', Validators.required],
  password: ['', Validators.required]
})

private setFormControlOrder(): void {
  const order = Object.keys(this.form.controls);
  console.log('order:', order);
  order.forEach(control => {
    const index = this.form.controls[control]['name'];
    console.log('index:', index);
    if (index === 'name') {
      const temp = this.form.controls[control];
      delete this.form.controls[control];
      this.form.controls[control] = temp;
    }
  });
}

在上例中,我们使用Object.keys()方法获取FormGroup中的每个FormControl的名称,并按FormGroup中的顺序对其进行排序。我们然后将FormGroup中“name”控件提到第一个位置。

然后,在component.ngOnInit()方法中,我们调用setFormControlOrder()来更新FormControl的顺序。

通过这种方式,您可以在绑定FormGroup的表单中指定FormControl的顺序,从而解决Angular表单中第一个输入元素不反映FormBuilder值的问题。

相关内容

热门资讯

透视有挂!wpk插件,wpk有... 透视有挂!wpk插件,wpk有那种辅助吗(透视)一直真的是有脚本(哔哩哔哩)1、金币登录送、破产送、...
透视讲解!wpk真的有透视嘛,... 透视讲解!wpk真的有透视嘛,手机微乐小程序自建房透视免费,科普脚本(有挂讲解)-哔哩哔哩1、不需要...
现有关情况通报如下!wepok... 现有关情况通报如下!wepoker怎么提高运气,微乐游戏竞技团辅助,揭露透视(的确有挂)-哔哩哔哩1...
备受关注的!wepoker免费... 备受关注的!wepoker免费脚本咨询,微信微乐辅助器免费,开挂脚本(有挂方法)-哔哩哔哩;wepo...
脚本总结!wpk有辅助器吗,w... 脚本总结!wpk有辅助器吗,wpk系统是否存在作必弊行为(透视)其实是真的挂(哔哩哔哩);1、实时透...
突发!wepoker透视器免费... 突发!wepoker透视器免费,微乐自建房脚本下载,开挂透视(有挂分析)-哔哩哔哩1、游戏颠覆性的策...
透视诀窍!aapoker辅助怎... 透视诀窍!aapoker辅助怎么用,AApoker辅助工具一直存在有脚本,第5分钟教程(有挂神器)1...
记者获悉!wepoker辅助器... 记者获悉!wepoker辅助器怎么弄,微乐小游戏万能修改器,揭露脚本(证实有挂)-哔哩哔哩1、打开软...
透视曝光!德普之星辅助器app... 透视曝光!德普之星辅助器app,德普之星怎么设置埋牌(透视)切实是有app(哔哩哔哩)1、这是跨平台...
透视有挂!wepokerplu... 透视有挂!wepokerplus透视脚本免费,微乐小程序黑科技辅助工具2026最新推荐,揭幕透视(有...