AngularMaterial+Formly:ValidationinsideNestedCustomTypes
创始人
2024-10-28 07:01:41
0

在使用 Angular Material 和 Formly 进行表单开发时,有时需要对嵌套的自定义类型进行验证。以下是一个示例,展示了如何在 Formly 模型中嵌套自定义类型并在 Angular Material 中添加验证。

首先,我们需要定义一个父级自定义类型,用于嵌套子级类型:

import { FormlyFieldConfig } from '@ngx-formly/core';

export interface NestedTypeModel {
  title: string;
  content: string;
  nested: NestedType;
}

export interface NestedType {
  title: string;
  content: string;
}

export class ParentType {
  static fieldGroup: FormlyFieldConfig[] = [
    {
      key: 'title',
      type: 'input',
      templateOptions: {
        label: 'Title',
        required: true,
      },
    },
    {
      key: 'content',
      type: 'textarea',
      templateOptions: {
        label: 'Content',
        required: true,
      },
    },
    {
      key: 'nested',
      type: 'custom',
      templateOptions: {
        label: 'Nested Type',
      },
      validators: {
        nested: {expression: 'formState.valid', message: 'Nested type is invalid'},
      },
      fieldGroup: [
        {
          key: 'title',
          type: 'input',
          templateOptions: {
            label: 'Title',
            required: true,
          },
        },
        {
          key: 'content',
          type: 'textarea',
          templateOptions: {
            label: 'Content',
            required: true,
          },
        },
      ],
    },
  ];
}

注意,在父级类型的 “validators” 对象中添加了一个自定义验证器“nested”,用于验证嵌套的子级类型是否有效。

接下来,我们需要定义一个自定义类型,该类型用于嵌套在父级类型中:

import { FormGroup } from '@angular/forms';
import { FormlyFieldConfig, FormlyFormOptions } from '@ngx-formly/core';
import { NestedTypeModel } from './parent-type.model';

export class NestedTypeComponent {
  title;
  content;
  form = new FormGroup({});
  options: FormlyFormOptions = {};
  fields: FormlyFieldConfig[] = [
    {
      key: 'title',
      type: 'input',
      templateOptions: {
        label: 'Title',
        required: true,
      },
      validators: {
        validTitle: {expression: '!!model.title && model.title.length > 5', message: 'Title must be at least 5 characters'},
      },
    },
    {
      key: 'content',
      type: 'textarea',
      templateOptions: {
        label: 'Content',
        required: true,
      },
      validators: {
        validContent: {expression: '!!model.content && model.content.length > 10', message: 'Content must be at least 10 characters'},
      },
    },
  ];

  constructor() {}

  get model(): NestedTypeModel {
    return {title: this.title, content: this.content, nested: null};
  }

  get formState(): any {
    return {valid: this.form.valid};
  }
}

在该自定义类型中,我们添加了一个表单分组和一些子级字段。还添加了一些自定义验证器来验证子级类型的特定字段。

最后,我们可以将父级类型和子级类型组合在一起,并将其添加到 Formly 的配置中:

相关内容

热门资讯

第7分钟开挂!微乐游戏小程序辅... 您好:这款微乐游戏小程序辅助器免费苹果版游戏是可以开挂的,确实是有挂的,很多玩家在这款微乐游戏小程序...
八分钟辅助!潮汕馆辅助,大唐山... 八分钟辅助!潮汕馆辅助,大唐山西辅助软件苹果版(玩家必备教程开挂辅助神器);大唐山西辅助软件苹果版简...
两分钟透视!谁有老友广东辅助器... 两分钟透视!谁有老友广东辅助器,wepoker破解是真的还是假的(透视科技开挂辅助安装)1、下载安装...
五分钟辅助!微友联盟辅助下载,... 《五分钟辅助!微友联盟辅助下载,好友赣南新版本挂(重大发现开挂辅助安装)》 好友赣南新版本挂软件透视...
6分钟透视!四川皮皮辅助挂,浙... 6分钟透视!四川皮皮辅助挂,浙江游戏大厅修改数据(总算了解开挂辅助平台);打开点击测试直接进入微信(...
4分钟辅助!水鱼辅助软件下载,... 4分钟辅助!水鱼辅助软件下载,微乐多乐跑作弊(透视透视挂开挂辅助神器);相信小伙伴都知道这个水鱼辅助...
两分钟开挂!花花生活圈怎么开挂... 两分钟开挂!花花生活圈怎么开挂,三哥玩辅助器免费下载(必备辅助推荐开挂辅助神器)您好:三哥玩辅助器免...
1分钟辅助!衢州都莱辅助器,蛮... 1分钟辅助!衢州都莱辅助器,蛮王大厅辅助插件(透视私人局开挂辅助脚本);是一款可以让一直输的玩家,快...
第八分钟辅助!wpk辅助器,斗... 第八分钟辅助!wpk辅助器,斗棋崇阳麻将辅助脚本(玩家必备科普开挂辅助软件);1、点击下载安装,斗棋...
第7分钟辅助!乐胡陇南摆叫辅助... 第7分钟辅助!乐胡陇南摆叫辅助器,决战卡五星开挂方法(每日必看推荐开挂辅助工具);无需打开直接搜索加...