业务中有大量复杂的嵌套表单,这使得研发难度上升。基于此,团队研发了一个表单库,但能力较为简单,而且性能不好、代码结构也不合理。 随着实力的不断提高。终于在 23 年新年假期期间想到,我要自己做一个开源表单库,并且希望此表单库能够为团队内的表单库优化带来动力。
- 文档:https://form-1305245006.cos-website.ap-shanghai.myqcloud.com
- 技术栈:Typescript、React、Recoil、Antd、
- 构建:模块化基于 ESM、构建基于 Rollup
- 目前基于 TS 提供 type 和 ESM。基于 Rollup 提供 UMD 和 UMD.min
其实一开始的实现方案不是下面的那个。
本来想的是基于 class 提供一些工具,然后 new 的时候赋值给 store,这样 store 就可以获得操纵表单的方法。
至于如何更新 Form.Item 组件,我想采用发布订阅模式,生成表单时注册 on 事件,并为 class 中需要更新的方法执行 emit 事件。当 on 绑定的事件被执行后,就执行 useState 的 set 函数,引起 Form.Item 组件更新。
但在开发完成后发现有一些莫名其妙的 bug(在写这些文字的时候,我已经忘记是什么 bug 了),我竟然无法解决。遂选择放弃,采用下面的方案
- UI:不想管!!市面上不同风格的 UI 组件数不胜出。我的表单可以只提供基础的数据管理能力,并且能够快速的适应不同的表单库(Form.Item)。
- 数据处理:数据管理方案采用 Recoil,并对其进行封装,输出一堆能够操纵表单各种信息的 Hook。我觉得 Recoil 的数据原子化思想很好(踩一下 Context,😁),能够很大程度上优化表单数据管理的性能。
- 表单校验使用 async-validator,在 onChang 时校验,完成后将错误传给 Form.Item
- 表单嵌套及复用:每一个根表单要有一个单独的 RecoilRoot,子表单封装成一个函数,接收一个表单状态 Store 即可直观的实现表单嵌套和复用,字段名称 field 采用 path 模式,这样可以方便的管理各级数据。
- 未来会提供一个生成子表单的方法 createSubForm