基于Antd Form组件的二次封装(演示说明)

前言

在之前的文章《基于Antd Form组件的二次封装,配置化生成表单、一级列表二级列表功能》中我们用代码的方式介绍了antd-form-multi组件库,

但是不直观的知道antd-form-multi组件库要实现什么样的功能,虽然有了演示地址,但还是有必要写一篇演示文章给大家说明。

antd-form-multi是一个基于Antd Form二次封装的便捷、高效、易于理解、且功能相对完整、适用于绝大多数业务场景的表单组件库。

这是一个纯前端的项目

github地址

github.com/CMG-CEO/ant...

github演示地址

cmg-ceo.github.io/antdform.gi...

安装

npm install antd-form-multi

或者

yarn add antd-form-multi

在组件内的<Form>(antd组件)内引用

import FormItem from 'antd-form-multi'

数据联动

这里可以看到,选择框1、选择框2控制后面控件的展示和隐藏

  • 选择框1 选择规则1-1我是规则1-1规则不是2-2 非必填 的输入框显示
  • 选择框1 选择规则1-2 我是规则1-2或2-1 显示 我是规则1-1 不显示
  • 选择框2 选择规则2-1 我是规则1-2或2-1 显示
  • 选择框2 选择规则2-2 规则2-2 必填 显示 我是规则1-2或2-1 不显示

这是将每一个输入框控件都进行编组,当选择框选择对应项时,将组规则进行更换,然后组件库自动会将符合组规则的输入框控件显示出来

这里只是隐藏显示,所以会保留之前填入的内容

一级列表

一级列表 ,指的是控件数据以数组的方式存放在表单的第一层级,并都在同一个数组内。实际上是对Antd中动态增减嵌套字段 进行扩展,并对其操作进行简化。

这里提供两种布局方式,

  • 有包裹器: 包裹器的样式可以使用默认或者自行引入、定义,你只需要配置WrapComponent: FormWrapCard,这一项即可.
  • 无包裹器:这种场景适用于一种类似于表格的展示页,如果你不想把重复的label显示出来,只需要配置openLabel: false

并且我们提供了一些快捷的操作,复制、移动的功能

vbnet 复制代码
wrapCopy: true,
wrapMove: true,

一级列表联动

结合一级列表和表单数据联动的功能,我们就实现了一级列表上的数据联动。

每一个一级列表之间规则独立,当一级列表项删除、重新排序之后,规则项也要对应的进行排序。同样复制一个列表项时,相应的规则也会复制。

这里的规则格式是 [[0,['group1']], [1,['group2','group3']]]

每一项都是一个数组

  • 第一项为数字 (0、1...)对应着一级列表的索引
  • 第二项为字符串数组 ,代表着这一个列表适用的规则
  • 所以当选择框改变时,我们通过 onChange 事件 找到对应的一级列表,进行修改规则

这里通过控制台输出可以看到表单的数据结构

二级列表

二级列表,指的是在一级列表里面还有一层列表。同样他的原理也是用Antd 的动态增减嵌套字段来实现。

这个演示中可以看到我们在一级列表中增加了多个输入框。

二级列表的参数项与一级列表一致 ,只是将leave1 换成 leave2 。这样保证了开发人员的心智负担。

二级列表联动

同样二级列表的数据联动和一级列表类似,配置项也保持一致

只是要区分他的组的规则格式 [[0,0,['group1']],[0,1,['group2','group3']]]

  • 第一项为数字 (0、1...)对应着一级列表的索引
  • 第二项为数字 (0、1...)对应着二级列表的索引
  • 第三项为字符串数组 ,代表着这一个列表适用的规则

额外的功能

在后续的文章中,我将再讲述一下,如何扩展使用,以及一些额外的功能。还有对其进行代码解析。

敬请期待!

谢谢!

相关推荐
西西小飞龙12 分钟前
Less/Sass Mixins vs. Extend
前端·less·sass
syjy214 分钟前
(含下载)BeTheme WordPress主题使用教程
前端·wordpress·wordpress建站
Misnice23 分钟前
shadcn如何使用
前端·reactjs
h_jQuery27 分钟前
vue使用gm-crypto对数据进行sm4加密处理
前端·javascript·vue.js
阿赛工作室1 小时前
Vue中onBeforeUnmount不触发的解决方案
前端·javascript·vue.js
码王吴彦祖1 小时前
顶象 AC 纯算法迁移实战:从补环境到纯算的完整拆解
java·前端·算法
小叶lr1 小时前
jenkins打包前端样式丢失/与本地不一致问题
运维·前端·jenkins
浩星1 小时前
electron系列1:Electron不是玩具,为什么桌面应用需要它?
前端·javascript·electron
ZC跨境爬虫2 小时前
Scrapy工作空间搭建与目录结构解析:从初始化到基础配置全流程
前端·爬虫·python·scrapy·自动化
小村儿2 小时前
连载04-最重要的Skill---一起吃透 Claude Code,告别 AI coding 迷茫
前端·后端·ai编程