antd tree 动态添加_Ant Design 动态表单示例,如何批量添加表单元素

319bc7521f355dd714802cd10b259c13.png

动态表单

复杂的后端管理系统,逃不掉表单项的动态增减,结合 Antd 就会有这几个问题:

  • 怎么在已经写好的 Form 表单中,增添新的表单元素?
  • 怎么友好的添加新表单字段?甚至是一批字段?
  • 这些字段怎么纳入原先的 validate 校验体系?

我参考官网的 动态增减表单项-示例 ,再“绞尽脑汁”准备了还算过得去的 demo。

下面看下效果图,同时我会做简单的说明:

41222d5cdc04678cad45011af337b624.gif

如何动态添加元素?

往页面上添加元素倒是不难,现在前端框架都是基于数据驱动的。

所以只要维护一个(数组)变量(例中为:dynamicGroup),然后根据修改逻辑,往这个数组中增减元素,最后通过 v-for 动态渲染出对应的表单标签即可。

f9a183af8d856634859ed82f80ddc06b.png

怎么友好添加新的表单字段?

在 dynamicGroup 动态元素集合中,我放的是“一批”动态的字段 dynamicFields(也是数组类型)。

ca085fe29d6a009a0f5645f256f24503.png

然后在对应的添加逻辑中,直接将预设的 dynamicFields 规则作为新元素放到 dynamicGroup 中:

3b2b3b849e10ee502428e9de87be268e.png

如果你每次添加的操作中,包含一批字段就可以维护在 dynamicFields 中,如果只有一个字段,就维护一个数组就行。

然后每个 dynamicFields 元素,可以维护 常用的属性(比如:label、placeholder...)

47e5050917f93042bee00ec960a94e42.png

怎么和表单校验联动处理?

你应该注意到:我在 dynamicFields 中的每个字段对象中定义了一个 decorator function 方法(而非 key-value)

a46418d65fa797da60f12f47edc4e602.png

原因就是,每批增加的表单项“们”都是相互独立的,而验证需要交给 v-decorator 实现,而这个指令需要接受一个“唯一值”:id,所以这里将 key 动态化。

这样最后 form 的验证就能根据不同的 key 进行独一无二的校验。

77e43f7923601442f48ce2058626f57e.png

注意到,因为每次成批添加,每批包含多个字段。所以这个 key 需要符合复杂对象的定义形式(antd 会帮我们解析到 form values):

0a095cfc1ddf45f5889c1bf54c0a9878.png

友情提示,一个数组结构内包含一个复杂对象采用上述结构,如果你用了如下形式是回显不了值的:

06d2f4a73798b003b24cd6e6f6d2b0dd.png

总结

示例代码可以应对大部分普通的动态表单需求,示例中没有做删除表单项的操作,不过也很简单相信各位能搞定!

最后,上述代码用于 Demo 示例说明,考虑不周之处,望见谅。

本文使用 mdnice 排版

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值