基于 Formily 的表单设计器实现原理分析

本文分析了基于 Formily 实现的表单设计器的工作原理。表单设计器提供可视化界面,允许非专业开发人员通过拖拽构建业务表单。设计师输出 JSON Schema,前端根据 Schema 渲染表单,降低开发人员对表单更新的介入。文章讨论了 Schema 的简化定义和设计器的主要功能,包括字段的添加、删除和更新。表单设计器的核心包括控件的配置、转化成 Schema 及 Schema 回显。Formily 的灵活性是实现这一功能的关键。
摘要由CSDN通过智能技术生成

作者:段国伟、汪曦

背景

在控制台类 web 应用中,表单是最常见的交互形式。用户在表单中填写信息,点击提交就能完成对数据创建或者修改操作。

最开始前端开发人员根据业务模型和具体需求,通过**逐一**编写或者声明实现表单中的各个字段,测试通过之后发布上线。渐渐的,开发人员开始把一些常用的方法抽象成表单库复用,提升开发效率。但随着业务复杂度的增加和需求的不断演进,对表单的展示形式和灵活程度要求也在不断提高,现有的表单库只能解决部分问题,开发者仍需花费大量的精力在更新表单字段或者开发新表单上。

那有没有一种方式,既能让开发人员快速构建表单,同时在后期又很少或者根本不需要开发人员介入来更新表单呢?

此时,表单设计器应运而生。表单设计器提供了可视化界面,让非专业开发人员也能通过拖拽的方式,所见即所得的构建业务所需表单。

表单设计器样式

目前很多开源的表单设计器实现,在 UI 上都大同小异,设计器的结构类似设计软件的布局。表单设计器一般为左中右三栏布局:

  • 左侧是控件列表,列出了设计器支持的表单控件;
  • 中间部分是画布(canvas) ,左侧的控件可直接拖拽到画布中,并支持控件调整顺序、复制等操作;
  • 右侧是表单字段的配置区域,在画布中选中一个字段,右侧将展示此字段的所有属性,用户可在此处配置字段标题、描述、校验规则等。

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值