Angular响应式表单数组排序是否需要同时对控件和值进行排序?
创始人
2024-10-30 07:01:08
0

首先,需要明确要排序的是表单数组中的哪个控件属性。假设要按照姓名属性进行排序,可以先将表单数组的值按照姓名属性进行排序,然后再将表单数组中的控件按照排好序的值更新顺序即可。

具体实现如下:

  1. 导入 Angular 表单相关模块:
import { FormArray, FormControl, FormGroup } from '@angular/forms';
  1. 获取表单数组控件:
formArray: FormArray = this.form.get('items') as FormArray;
  1. 根据姓名属性,定义排序的比较函数:
sortByName(a: FormGroup, b: FormGroup) {
  const nameA = a.get('name').value.toLowerCase();
  const nameB = b.get('name').value.toLowerCase();
  if (nameA < nameB) {
    return -1;
  }
  if (nameA > nameB) {
    return 1;
  }
  return 0;
}
  1. 对表单数组中的值按照姓名属性进行排序:
this.formArray.controls.sort(this.sortByName);
  1. 更新表单数组中控件的顺序:
const sortedFormGroups = this.formArray.controls.map(control => control.value);
this.formArray.clear();
for (const item of sortedFormGroups) {
  this.formArray.push(new FormGroup({
    name: new FormControl(item.name),
    age: new FormControl(item.age)
  }));
}

其中,sortedFormGroups 是经过排序后的表单数组值的数组,clear() 方法用于清空表单数组,然后遍历 sortedFormGroups 中的每个元素,将其按照顺序添加到表单数组中。

完整示例代码如下:

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

@Component({
  selector: 'app-form-array-sort',
  template: `

相关内容

热门资讯

透视美元局!中至江西源代码,w... 透视美元局!中至江西源代码,wepoker游戏的安装教程(辅助挂)详细开挂辅助器1、下载安装好wep...
今日焦点!奇迹手游辅助,阿拉游... >>您好:阿拉游戏中心辅助工具确实是有挂的,很多玩家在这款阿拉游戏中心辅助工具游戏中打牌都会发现很多...
透视线上!浙江宝宝游戏辅助器,... 透视线上!浙江宝宝游戏辅助器,hhpoker作弊码怎么用(辅助挂)详细开挂辅助下载 了解更多开挂安装...
攻略讲解!极速官方暗堡透视,对... 您好:这款极速官方暗堡透视游戏是可以开挂的,确实是有挂的,很多玩家在这款极速官方暗堡透视游戏中打牌都...
透视好友!pokermaste... 透视好友!pokermaster破解版,wepoker辅助真的假的(辅助挂)详细开挂辅助神器;无需打...
信息共享!传送屋app辅助脚本... 大家好,今天小编来为大家解答传送屋app辅助脚本下载这个问题咨询软件客服可以免费测试直接加微信(13...
透视玄学!wepoker手机助... 您好:这款红龙poker辅助平台游戏是可以开挂的,确实是有挂的,很多玩家在这款红龙poker辅助平台...
新手必备!四川家园辅助器,陕麻... 新手必备!四川家园辅助器,陕麻圈有辅助吗(有挂方法辅助插件);无需打开直接搜索打开薇:1367043...
必知教程!潮汕娱手机暗宝透视,... 必知教程!潮汕娱手机暗宝透视,反杀大厅辅助(证实有挂开挂辅助下载);无需打开直接搜索薇:136704...
透视苹果版!德普之星透视辅助软... 透视苹果版!德普之星透视辅助软件激活码,wepoker到底有没有透视(辅助挂)详细开挂辅助器 了解更...