如何设计一个表单引擎?(如何设计一个表单引擎)

表单的本质是业务,没有表单是无法完成业务系统的,而动态表单使业务系统更高级。动态表单是什么呢?它是如何工作的?应用场景有哪些?一起来看一下吧。

如何设计一个表单引擎?(如何设计一个表单引擎)

一、表单

表单在网页中主要负责数据采集功能,是提交数据的一切形式。表单的本质是提交数据,不仅仅包含输入框、下拉选择框等这些控件,常见的按钮空间也属于一个表单。

1. 动态表单

动态表单(Dynamic Form),指在前端运行过程中可依赖某些业务逻辑发生表单项变化的表单,还包括表单布局、表单数据管理、表单校验、表单交互、表单项联动逻辑等原本由前端编程完成的表单开发,转由后端通过 API 接口输出表单描述自动完成上述所有内容的表单开发形式。

如何设计一个表单引擎?(如何设计一个表单引擎)

(动态表单原理示意图)

2. 动态表单的特点优势

表单的本质是业务,而动态表单使业务系统更高级。

普通表单是一个表单写一份前端的代码,代码全部由前端开发者完成(后端配合接口输出)。而动态表单则是一个表单对应一个 JSON(由后端输出),所有表单由一份代码(动态表单引擎)进行加载和渲染。

所以,动态表单具有以下优势:

  • 客户端运行的代码量更少;
  • 每个表单的JSON按需加载;
  • 表单需求变化时,无需前端修改发版,只需编辑数据库中的JSON。

二、表单控件

表单控件是提供一组允许用户操作的对象,从而接收用户输入的数据,用户可操作该对象来执行对表单设计,修改等操作。

1. HTML表单种常见的13个控件

input元素无疑是一个庞大和复杂的元素,但它并不是唯一的表单控件。还有button、select、option、label、optgroup、textarea、fieldset、legend这八个传统表单控件,datalist、progress、meter、output、keygen这五个新增表单控件。

如何设计一个表单引擎?(如何设计一个表单引擎)

2. 动态表单控件

动态表单是老厂商天翎核心技术之一,也是天翎公司核心产品MyApps的重要组成部分。通过对于动态表单的应用,可以避免在电子流程系统中硬编码的数据采集及处理表单,提高系统的可维护性。

如何设计一个表单引擎?(如何设计一个表单引擎)

说明:

Form,动态表单实现的基本入口,描述了DynaForm的最基本属性,比如名称、ID、以及最核心的TemplateContext。TemplateContext中保存的是Form的描述XML,通过此XML描述两类信息:

  1. Form中所具有的Field以及Field的类型、名称、长度、计算代码等等,XML;
  2. Form的格式,比如排列次序、表格定列化的过程当中,系统自动解析XML的内容并将其转换为Java Object并由此具备Object的行为特性;位等。Form作为一个ValueObject存储在数据库中。

FormElement,接口,表示Form中的基本元素;

FormField,动态表单的最基本元素,在myApps/OBPM中被声明为Abstract,具体Object行为依赖于具体的SubClass实现;

TextField,单行文本框,继承FormField;

SelectField,下拉选择框,继承FormField;

TextareaField,多行文本框,继承FormField;

CheckBoxField,复选框,继承FormField;

RadioBoxField,单选框,继承FormField;

Textpart,静态文本段,除各种Field以外的静态文本部分,继承FormElement;

ComponentField,自定义组件,继承FormField;

AttachmentUploadField,附件上传组件,继承FormField;

ImageUploadField,图片上传组件,继承FormField;

ViewDialogField,视图组件,用于实现主从结构的表单,继承FormField;

CalctextField,计算文本组件,用于实现需要计算的文本,继承FormField;

IncludeField,实现SubForm的包含,继承FormField;

WordField,Word组件,继承FormField;

OcrField,为将来预留的接口,系统暂未实现;

三、表单引擎

表单引擎是为快速实施项目研发的轻量级表单设计工具。采用表单引擎工具可在不开发和新增加代码的情况下设计出新表单样式,同比程序开发可省掉程序员差不多70%的开发工作量,并且后期维护相对简单,管理方便。

1. 工作原理

在了解了表单的基本机构后,进一步看看表单引擎是如何工作的。

从客户端(Client)输入数据(Document),比如一个excel文件,表单(Form)结合excel文件自动生成HTML,如下图:

如何设计一个表单引擎?(如何设计一个表单引擎)

(表单结合文档生成HTML过程)

如何设计一个表单引擎?(如何设计一个表单引擎)

(XML解析为表单对象的过程)

如何设计一个表单引擎?(如何设计一个表单引擎)

(表单转为HTML过程)

如何设计一个表单引擎?(如何设计一个表单引擎)

(表单生成数据库)

2. 应用场景

天翎Myapps低代码开发平台的表单引擎是基于Web界面上可视化编辑的表单设计系统,同时支持印刷模式和拖拽模式两种设计方式,形象可见,操作方便。印刷模式可以做一些复杂的表单配置,同时还支持word表格的导入;拖拽模式:基于Vue的表单设计器,采用可视化拖拉拽的模式进行表单的设计。

如何设计一个表单引擎?(如何设计一个表单引擎)如何设计一个表单引擎?(如何设计一个表单引擎)

(表单前台)

如何设计一个表单引擎?(如何设计一个表单引擎)

(表单后台)

本文由 @周志军Jarod 原创发布于人人都是产品经理,未经作者许可,禁止转载。

题图来自Unsplash,基于CC0协议

该文观点仅代表作者本人,人人都是产品经理平台仅提供信息存储空间服务。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年5月14日 下午3:38
下一篇 2024年5月14日 下午3:50

相关推荐

  • 三菱FX3GA 和西门子触摸屏422通讯

    三菱FX3GA和西门子触摸屏422通讯 三菱FX3GA是一款高性能的PLC,而西门子触摸屏422是一款先进的触摸控制板。这两种设备之间的通讯是PLC与触摸控制板之间的一种重要连接方…

    联系我们 2024年12月1日
    3
  • 软件开发者路线图从学徒到高手

    软件开发者路线图:从学徒到高手 软件开发是一项非常复杂和具有挑战性的工作,需要不断学习和提高自己的技能。对于初学者来说,成为有经验的软件开发者可能需要多年的时间和努力。本文将介绍软…

    联系我们 2024年12月10日
    0
  • 苏文电能-电力电子设备及储能技术研发中心建设项目可行性报告

    1、项目基本情况 本项目将由上市公司实施。本项目将购置先进的研发、检测和试验设备和软 件,引进行业优秀技术人才,建成一个先进的电力电子设备及储能技术研发中心。 本项目将对新能源储能…

    联系我们 2022年4月29日
    339
  • 内部资金转移定价的作用

    内部资金转移定价的作用 内部资金转移定价是指企业为实现内部资金转移而进行定价的一种机制,其目的是在保持资金流动的前提下,最大化企业的利润和效益。内部资金转移定价的作用主要包括以下几…

    联系我们 2024年12月2日
    1
  • 研究的考核指标,预期阶段性成果、最终成果,经济社会效益及 其推广应用(包

    研究的考核指标: 本研究的预期阶段性成果和最终成果是: 预期阶段性成果: 1. 建立一种新的蛋白质修饰机制,该机制可以用于开发新的药物和治疗方法。 2. 开发一种新的基因编辑技术,…

    联系我们 2024年12月6日
    1
  • 开票软件v3运行环境

    开票软件v3运行环境介绍 随着商业的发展,开票软件v3已经成为企业财务部门不可或缺的一部分。开票软件v3可以为企业提供高效、准确、可靠的财务处理服务,使得企业能够更好地管理财务,提…

    联系我们 2024年12月4日
    0
  • 科研项目的项目基础

    科研项目的项目基础 科研项目的项目基础非常重要,它是整个项目成功的关键。一个好的项目基础需要包括以下几个方面: 1. 明确的研究目标:科研项目需要有一个明确的研究目标,这是指希望通…

    联系我们 2024年12月8日
    0
  • 文科类科研的流程

    科研流程是进行科学研究的基础,对于文科类研究来说尤为重要。文科类研究通常需要对大量文献进行阅读和文献综述,以便确定研究方向和问题。 以下是一些常见的文科类科研流程: 1. 确定研究…

    联系我们 2024年12月6日
    2
  • 去重播放器

    去重播放器是一款功能强大的文本去重工具,能够轻松帮助您消除文本中的重复内容。无论是复制粘贴还是手动输入,去重播放器都可以让您轻松去除重复的文本内容,从而提高工作效率和文件安全性。 …

    联系我们 2024年12月4日
    0