Angular对数组进行排序会导致formGroup中的最后一个控件失效。
创始人
2024-10-24 15:31:42
0

解决这个问题的一种方法是使用Angular的FormArray来替代FormGroup中的数组,并在排序后重新建立表单控件。以下是一个示例代码:

import { Component, OnInit } from '@angular/core';
import { FormGroup, FormBuilder, FormArray } from '@angular/forms';

@Component({
  selector: 'app-my-component',
  templateUrl: './my-component.component.html',
  styleUrls: ['./my-component.component.css']
})
export class MyComponentComponent implements OnInit {
  myForm: FormGroup;

  constructor(private fb: FormBuilder) {}

  ngOnInit(): void {
    this.initializeForm();
  }

  initializeForm(): void {
    this.myForm = this.fb.group({
      myArray: this.fb.array([])
    });

    // 添加初始表单控件
    this.addFormControls();
  }

  addFormControls(): void {
    const controlArray = this.myForm.get('myArray') as FormArray;

    controlArray.push(this.fb.control('Value 1'));
    controlArray.push(this.fb.control('Value 2'));
    controlArray.push(this.fb.control('Value 3'));
  }

  sortArray(): void {
    const controlArray = this.myForm.get('myArray') as FormArray;

    // 对数组进行排序
    controlArray.controls.sort((a, b) => {
      if (a.value < b.value) {
        return -1;
      } else if (a.value > b.value) {
        return 1;
      } else {
        return 0;
      }
    });

    // 重新建立表单控件
    const sortedArray = this.fb.array(controlArray.controls.map(control => control.value));
    this.myForm.setControl('myArray', sortedArray);
  }
}

上述代码中,我们使用FormArray来代替FormGroup中的数组。在initializeForm方法中,我们初始化了myForm并添加了初始表单控件。在sortArray方法中,我们对数组进行了排序,并重新建立了表单控件。

请注意,在模板中使用myForm时,需要使用formArrayNameformGroupName来正确绑定和显示表单控件。

相关内容

热门资讯

黑科技科技(wepoke智能a... 黑科技科技(wepoke智能ai)wepower使用说明书(wepOkE)素来是真的有挂(确实有挂)...
黑科技模拟器(wepoke智能... WePoker透视辅助工具核心要点解析‌,黑科技模拟器(wepoke智能ai)wepoke是机器发牌...
黑科技脚本(wepokeai代... 您好,这款游戏可以开挂的,确实是有挂的,需要了解加微【136704302】很多玩家在这款游戏中打牌都...
黑科技辅助挂(wepoke真的... 黑科技辅助挂(wepoke真的有挂)wepoke 软件(wEPOKE)固有真的有挂(有挂猫腻)-哔哩...
黑科技辅助挂(wepoke黑科... 黑科技辅助挂(wepoke黑科技)wepoke软件透明挂演示(wEpOke)一直真的有挂(真的有挂)...
黑科技app(wepoke真的... 此外,数据分析德州()辅助神器app还具备辅助透视行为开挂功能,通过对客户透明挂的深入研究,你可以了...
黑科技智能ai(wepoke辅... 黑科技智能ai(wepoke辅助插件)wepoke软件透明(WEPOke)先前是有挂(果真有挂)-哔...
黑科技模拟器(wepoke透明... 黑科技模拟器(wepoke透明黑科技)wepoke德州扑克用ai代打(WEPOKE)最初存在有挂(有...
黑科技插件(wepoke辅助插... 黑科技插件(wepoke辅助插件)wepoke软件透明(WEPOke)从来是真的有挂(有挂解惑)-哔...
黑科技美元局(wepoke智能... 黑科技美元局(wepoke智能ai)wepoke辅助真的假的(wepoKE)原先真的有挂(竟然有挂)...