CN113760287A - 一种基于json结构的表单创建方法及设备 - Google Patents
一种基于json结构的表单创建方法及设备 Download PDFInfo
- Publication number
- CN113760287A CN113760287A CN202110983930.3A CN202110983930A CN113760287A CN 113760287 A CN113760287 A CN 113760287A CN 202110983930 A CN202110983930 A CN 202110983930A CN 113760287 A CN113760287 A CN 113760287A
- Authority
- CN
- China
- Prior art keywords
- model
- template
- json structure
- type
- field
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
- 238000000034 method Methods 0.000 title claims abstract description 43
- 238000013507 mapping Methods 0.000 claims description 5
- 230000008676 import Effects 0.000 claims description 4
- 238000005096 rolling process Methods 0.000 claims description 4
- 230000008569 process Effects 0.000 abstract description 8
- 230000000007 visual effect Effects 0.000 abstract description 2
- 238000011161 development Methods 0.000 description 4
- 238000010586 diagram Methods 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 239000000463 material Substances 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 238000012545 processing Methods 0.000 description 2
- 238000012549 training Methods 0.000 description 2
- 230000004075 alteration Effects 0.000 description 1
- 230000009286 beneficial effect Effects 0.000 description 1
- 238000013499 data model Methods 0.000 description 1
- 230000009977 dual effect Effects 0.000 description 1
- 235000013399 edible fruits Nutrition 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 230000000750 progressive effect Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F8/00—Arrangements for software engineering
- G06F8/30—Creation or generation of source code
- G06F8/38—Creation or generation of source code for implementing user interfaces
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F40/00—Handling natural language data
- G06F40/10—Text processing
- G06F40/166—Editing, e.g. inserting or deleting
- G06F40/186—Templates
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Health & Medical Sciences (AREA)
- Artificial Intelligence (AREA)
- Audiology, Speech & Language Pathology (AREA)
- Computational Linguistics (AREA)
- General Health & Medical Sciences (AREA)
- User Interface Of Digital Computer (AREA)
Abstract
本说明书实施例公开了一种基于JSON结构的表单创建方法及设备,方法包括:根据表单的使用类型选择对应的表单模板,其中,表单模板使用JSON结构进行描述,表单模板的JSON结构包括:数据实体模型、组件模型和视图模型根据所述单的使用场景选择对应的表单数据实体模型,其中,表单数据实体模型包括字段信息;根据使用场景选择表单展示的字段信息,以用于确定表单对应的组件模型和视图模型,并根据表单对应的组件模型和视图模型完成表单创建;用户只需选择表单模板、数据库表以及待展示的字段便可以完成表单的创建,降低了操作难度和用户的使用门槛,用户可以通过直观、简单的前端界面完成表单的创建,简化了表单创建过程。
Description
技术领域
本说明书涉及表单创建领域,尤其涉及一种基于JSON结构的表单创建方法及设备。
背景技术
在软件产品的开发过程中,应根据客户的需求进行开发,随着互联网技术的普及,大部分企业都会使用到自动化办公、审批流等表单,但是,每家企业对于表单的需求迥然不同,并且处理不同的事件必然使用不同的表单,这就需要配置生成不同的表单,因此,客户需要根据不同场景定制表单JSON的内容。
现有技术中,直接将表单的JSON结构暴露给前端客户,需要花费人力、物力去给客户做基础的技能培训,但仍然会存在大量来自客户理解、操作、技能方面的问题,导致产品的操作难度大、不利于用户的使用。
发明内容
本说明书一个或多个实施例提供了一种基于JSON结构的表单创建方法及设备,用于解决如下技术问题:现有技术中存在用户操作难度大、不便于用户使用的问题。
本说明书一个或多个实施例采用下述技术方案:
本说明书一个或多个实施例提供一种基于JSON结构的表单创建方法,所述方法包括:根据所述表单的使用类型选择对应的表单模板,其中,所述表单模板使用JSON结构进行描述,所述表单模板的JSON结构包括:数据实体模型、组件模型和视图模型;根据所述表单的使用场景选择对应的表单数据实体模型,其中,所述表单数据实体模型包括字段信息;根据所述使用场景选择所述表单展示的所述字段信息,以用于确定所述表单对应的组件模型和视图模型,并根据所述表单对应的组件模型和视图模型完成所述表单创建。
进一步地,所述根据所述表单使用类型选择对应的表单模板之前,所述方法还包括:预置多种类型的表单模板,其中,所述表单模板的类型包括列表界面模板、双列表界面模板、卡片界面模板、左列表右卡片界面模板、树表界面模板、左树右卡片界面模板、左树右列表界面模板、批量编辑列表界面模板、向导界面模板以及滚动定位卡片界面模板中的一项或多项。
进一步地,所述根据所述表单的使用场景选择对应的表单数据实体模型,具体包括:根据所述表单的使用场景选择所述表单对应的数据库表;预先将所述数据库表转化为对应的所述表单数据实体模型,以便于根据用户选择的所述数据库表,选择所述数据库表对应的表单数据实体模型。
进一步地,所述字段信息包括:字段类型以及字段对应的表单控件类型;所述根据使用场景选择表单展示的所述表单数据实体模型中的字段信息,具体包括:根据所述表单的使用场景,选择待展示的字段;根据所述待展示的字段的字段信息确定所述表单的表单控件类型,并生成对应的控件JSON结构。
进一步地,所述根据所述待展示的字段的字段类型确定所述表单的表单控件类型,并生成对应的控件JSON结构,具体包括:当用户选择的待展示的字段的字段类型为数字类型时,确定所述表单的表单控件类型为数字控件类型,并生成对应的数字控件JSON结构。
进一步地,所述确定所述表单对应的组件模型和视图模型,具体包括:根据所述表单对应的表单模板的类型,将所述表单划分为至少一个组件区域,所述组件区域包括列表区域、卡片区域以及数表区域中的一项或多项;将每个所述组件区域定义为对应的组件模型和视图模型,其中,所述组件模型与所述视图模型为一对一映射的关系;将所述控件JSON结构设置在所述组件模型中,并在对应的所述视图模型中记录所述字段信息。
进一步地,所述表单模板的JSON结构还包括状态机模型,以用于控制表单运行时的状态切换,其中所述表单运行时的状态包括只读状态和编辑状态。
进一步地,所述完成表单创建之前,所述方法还包括:根据用户需求预置所述表单的高级特性,其中,所述表单的高级特性包括以下一项或多项:启用审批工作流程、启用数据导入导出以及启用附件上传下载。
进一步地,所述根据用户需求预置所述表单的高级特性,具体包括:根据用户需求确定所述表单的高级特性的类型,基于所述高级特征的类型在所述组件模型中添加对应的组件,并在所述视图模型中添加对应的命令,生成与所述高级特性相关的JSON结构。
本说明书一个或多个实施例提供一种基于JSON结构的表单创建设备,包括:至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够:
根据所述表单的使用类型选择对应的表单模板,其中,所述表单模板使用JSON结构进行描述,所述表单模板的JSON结构包括:数据实体模型、组件模型和视图模型;
根据所述表单的使用场景选择对应的表单数据实体模型,其中,所述表单数据实体模型包括字段信息;
根据所述使用场景选择所述表单展示的所述字段信息,以用于确定所述表单对应的组件模型和视图模型,并根据所述表单对应的组件模型和视图模型完成所述表单创建。
本说明书实施例采用的上述至少一个技术方案能够达到以下有益效果:预先设置表单的JSON结构,根据表单的使用类型选择预先设置的表单模板,进一步根据使用场景确定与数据库对应的表单数据实体模型,用户选择待展示的字段信息后,生成对应的组件模型和视图模型,完成表单的创建,用户只需选择表单模板、数据库表以及待展示的字段便可以完成表单的创建,降低了操作难度和用户的使用门槛,用户可以通过直观、简单的前端界面完成表单的创建,简化了表单创建过程。
附图说明
为了更清楚地说明本说明书实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图仅仅是本说明书中记载的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动性的前提下,还可以根据这些附图获得其他的附图。在附图中:
图1为本说明书实施例提供的一种基于JSON结构的表单创建方法流程示意图;
图2为本说明书实施例提供的另一种基于JSON结构的表单创建方法流程示意图;
图3为本说明书实施例提供的一种基于JSON结构的表单创建设备的结构示意图。
具体实施方式
为了使本技术领域的人员更好地理解本说明书中的技术方案,下面将结合本说明书实施例中的附图,对本说明书实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例仅仅是本说明书一部分实施例,而不是全部的实施例。基于本说明书实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都应当属于本说明书保护的范围。
在软件产品的开发过程中,应根据客户的需求进行开发,随着互联网技术的普及,企业会借助互联网技术简化办公流程,大部分企业都会使用到自动化办公、审批流等表单业务。但是,每家企业对于表单的需求又是迥然不同的,这就需要配置生成不同的表单。因此,客户需要根据不同场景定制表单JSON的内容。
表单是以JSON格式描述的,若将表单的JSON结构直接在前端展示给客户,客户需要对JSON结构充分学习之后,才可以对表单进行操作,这极大的提高了产品的使用门槛,并且需要花费人力、物力去给客户做基础的技能培训,即便是这样,仍然会存在大量来自客户理解、操作、技能方面的问题。这就使得现有的将JSON结构展示给前端用户的表单创建方法,无法满足用户的定制化场景需求,并且导致产品的操作难度大、不便于用户使用。
本说明书实施例提供一种基于JSON结构的表单创建方法,图1为方法的流程示意图,如图1所示,方法包括如下步骤:
步骤S101,根据表单的使用类型选择对应的表单模板。
在步骤S101之前,还包括:预置多种类型的表单模板,其中,表单模板的类型包括列表界面模板、双列表界面模板、卡片界面模板、左列表右卡片界面模板、树表界面模板、左树右卡片界面模板、左树右列表界面模板、批量编辑列表界面模板、向导界面模板以及滚动定位卡片界面模板中的一项或多项。
在本说明书的一个实施例中,预先设置了多种类型的表单模板,以便于满足用户的多种使用场景。其中,表单模板的类型包括:列表界面模板、双列表界面模板、卡片界面模板、左列表右卡片界面模板、树表界面模板、左树右卡片界面模板、左树右列表界面模板、批量编辑列表界面模板、向导界面模板以及滚动定位卡片界面模板。
列表界面模板是以列表的形式展示数据,例如,统计学生成绩的应用场景下,使用列表的形式展示班级所有同学的成绩;双列表界面模板是指在表单中使用两个列表对数据进行展示,例如,以双列表的形式展示任一同学的两次成绩,能起到更好的对比效果;卡片界面是指以卡片形式展示数据,左列表右卡片界面模板是指在表单的左侧为列表的形式,右边是卡片的形式,例如,在财务产品的报销单据中左侧列表处对应的报销人信息,右侧以卡片的形式展示具体的报销单信息;树表界面模板是指以数表的形式展示,例如,公司组织结构和层级结构的表单数据可以是数表的形式进行展示,其他的模板本说明书在此不做具体限定。通过设置多种不同类型的表单模板,满足了用户的多种不同场景下的使用需求。
具体地,步骤S101包括:表单模板使用JSON结构进行描述,表单模板的JSON结构包括:数据实体模型、组件模型和视图模型;表单模板的JSON结构还包括状态机模型,以用于控制表单运行时的状态切换,其中表单运行时的状态包括只读状态和编辑状态。
在本说明书的一个实施例中,用户根据使用场景选择对应的表单模板,需要说明的是,表单模板以JSON结构进行描述,主要包括模板标识、数据实体模型、状态机模型、组件模型、视图模型等内容。其中模板标识用于表示表单创建时所使用的模板的标识,数据实体模型描述了表单对应的数据库表结构、字段结构以及多表之间的关联关系。状态机模型描述了表单页面运行时在只读态、编辑态之间的状态流转规则,可以将此规则绑定在控件上,用来实现控件在只读和编辑态之间的自动切换。组件模型描述组件内部的控件结构,控件绑定数据实体的某一字段,从而实现数据的存取。视图模型与组件模型为一对一映射,它描述了组件对应的字段简要结构以及组件内部所用的命令和命令的参数信息,组件内部控件通过绑定命令来实现点击、刷新等动作的脚本。表单JSON描述结构还包括:表单标识、表单名称、表单创建人等,如下表所示。
步骤S102,根据表单的使用场景选择对应的表单数据实体模型。
具体地,步骤S102包括:根据表单的使用场景选择表单对应的数据库表;预先将数据库表转化为对应的所述表单数据实体模型,以便于根据用户选择的数据库表,选择数据库表对应的表单数据实体模型。
在创建表单时,用户需要选择表单对应的数据库。在本说明书的一个实施例中,预先将多个数据库表转换为对应的表单数据实体模型,用户根据实际的表单使用场景选择表单对应的数据库表,以便于选择数据库表对应的表单数据实体模型。通过预先将数据库表转换为对应的表单数据实体模型,用户在使用表单时,只需要选择对应的数据库表即可,操作方便,降低了用户的使用门槛。需要说明的是,表单数据实体模型包括实体标识、实体编号、实体名称以及实体类型描述结构,具体属性值如下表所示。
属性ID | 属性名称 | 值类型 | 是否必填 | 说明 |
id | 实体标识 | 字符串 | 是 | 实体唯一标识 |
code | 实体编号 | 字符串 | 是 | 实体编号 |
name | 实体名称 | 字符串 | 是 | 实体名称 |
type | 实体类型描述结构 | FormSchemaEntityType | 是 | 实体类型描述结构 |
实体类型描述结构包括实体展示字段、主键字段编号、实体字段以及子实体,具体属性值见下表。
属性ID | 属性名称 | 值类型 | 是否必填 | 说明 |
displayName | 实体展示名称 | 字符串 | 是 | 实体展示名称 |
primary | 主键字段编号 | 字符串 | 是 | 实体的主键字段编号 |
fields | 实体字段 | FormSchemaEntityField[] | 是 | 实体字段信息 |
entities | 子实体 | FormSchemaEntity[] | 否 | 子实体模型 |
其中,实体字段对应的表单实体字段模型包括:字段标识、字段编号、字段名称、字段类型、字段默认值、字段是否必填、字段是否制度、字段长度、字段精度、表单控件类型以及字段路径等信息,具体参见下表。
在表单实体字段模型中字段类型涵盖了文本(string)、备注(text)、布尔(boolean)、数字(number)、枚举(enum)、日期(date)、日期时间(datetime)等基本的数据类型。
步骤S103,根据使用场景选择表单展示的字段信息,以用于确定表单对应的组件模型和视图模型,并根据表单对应的组件模型和视图模型完成表单创建。
具体地,步骤S103中根据使用场景选择表单展示的表单数据实体模型中的字段信息,具体包括:根据表单的使用场景,选择待展示的字段;根据所述待展示的字段的字段信息确定表单的表单控件类型,并生成对应的控件JSON结构,字段信息包括:字段类型以及字段对应的表单控件类型。当用户选择的待展示的字段的字段类型为数字类型时,确定表单的表单控件类型为数字控件类型,并生成对应的数字控件JSON结构。
在本说明书的一个实施例中,根据表单的使用场景选择在表单中待展示的字段,并根据对应的字段信息,确定表单的表单控件类型,并生成对应的控件JSON结构。字段中包括文本、备注、布尔、数字、枚举、日期、日期时间等基本的数据类型。当待展示的字段的字段类型为文本类型时,生成一份文本控件的JSON结构,例如用户在表单中展示的字段为性别时,字段信息为文本类型,则生成一份文本控件的JSON结构。当待展示的字段的字段类型为备注类型时,生成一份备注控件的JSON结构。当待展示的字段的字段类型为布尔类型时,生成一份布尔控件的JSON结构;当待展示的字段的字段类型为数字类型时,生成一份数字控件的JSON结构,例如待展示的信息为成绩、金额等,并将字段的必填、只读、长度、精度等属性映射到数字控件上,进而形成针对用户的输入型限制,例如金额的长度为小数点后两位;当待展示的字段的字段类型为枚举类型时,生成一份枚举控件的JSON结构;当待展示的字段的字段类型为日期类型时,生成一份日期控件的JSON结构;当待展示的字段的字段类型为日期时间类型时,生成一份日期时间控件的JSON结构。用户在使用表单时,只需要选择待展示的字段,便可以生成字段类型对应的控件JSON结构,以动态创建控件的方式生成一份标准代码结构,不需要用户掌握原理和各种使用规则,便可以创建出不同展示字段对应的JSON结构,降低了用户的使用门槛,简化了表单创建过程,方便用户操作。
具体地,步骤S103中确定所述表单对应的组件模型和视图模型,具体包括:根据表单对应的表单模板的类型,将表单划分为至少一个组件区域,组件区域包括列表区域、卡片区域以及数表区域中的一项或多项;将每个组件区域定义为对应的组件模型和视图模型,其中,组件模型与视图模型为一对一映射的关系;将控件JSON结构设置在组件模型中,并在对应的所述视图模型中记录字段信息。
在本说明书的一个实施例中,根据表单对应的表单模板的类型确定表单对应的组件模型和视图模型。需要说明的是,在本说明书的一个实施例中,每种表单模型都根据展示的页面元素将表单划分为了不同的组件区域。例如,使用列表界面模板的表单中包括列表区域,使用双列表界面模板的表单中包括两个列表区域,使用左列表右卡片界面模板的表单中包括一个列表区域和一个卡片界面区域,使用其他类型的表单模板的表单的区域划分在此不做赘述。将表单划分为不同的组件区域后,每一个组件区域对应一个组件模型和视图模型,其中组件模型和视图模型为一一对应的关系。
在本说明书的一个实施例中,以可视化界面的形式方便用户根据使用场景选择表单上待展示的字段。具体如下:在表单界面中以树形的方式展示数据实体以及对应的子实体,用户在切换数据实体时展示数据实体中定义的字段列表,用户根据需求勾选待展示的字段。
根据用户选择的字段的字段类型生成对应类型的控件JSON结构,并将生成的控件JSON结构按照区域划分放到了不同的组件中,并在对应的视图模型中记录字段简要信息。例如,用户在创建成绩表单的过程中,需要展示学生姓名、数学成绩信息,在表单界面中以树形的方式展示学生成绩单以及对应的子实体数学成绩单,在切换数据实体时展示学生姓名以及数学成绩的字段信息,用户选择该字段,根据学生姓名对应的文本类型和数学成绩对应的数字类型,分别生成文本控件JSON结构和数字控件JSON结构,将文本控件JSON结构和数字控件JSON结构分别放置在不同的组件模型中,在对应的视图模型中记录字段简要信息。
在本说明书的一个实施例中,若组件需要预置初始化、点击操作等事件,则会在视图模型中记录命令和命令参数的信息。
在步骤S103之后,方法还包括:根据用户需求预置表单的高级特性,其中,表单的高级特性包括以下一项或多项:启用审批工作流程、启用数据导入导出以及启用附件上传下载。其中,根据用户需求预置表单的高级特性,具体包括:根据用户需求确定表单的高级特性的类型,基于高级特征的类型在组件模型中添加对应的组件,并在视图模型中添加对应的命令,生成与高级特性相关的JSON结构。
在实际应用场景中,用户可能会存在除了完成表单内容之外其他的高级操作,例如当表单类型为报销单据时,需要将该单价提交上级审批,因此会用到启用审批工作流程。因此,本说明书实施例为了满足用户的需求,预支了表单的高级特性,包括:启用审批工作流程、启用数据导入导出以及启用附件上传下载,用户在需要使用表单高级特性时,可以勾选对应的高级特性进行使用。
用户在选择表单高级特性后,在组件模型中添加对应的组件,并在视图模型中添加对应的命令,生成与高级特性有关的JSON结构。例如用户启用审批工作流程后,会在表单组件模型中增加“提交审批”、“取消提交审批”两个按钮,并在视图模型中增加审批逻辑相关的命令,这样由本向导创建出的表单就自动启用了审批逻辑,不再需要用户手写审批相关的JSON结构,降低了产品的使用门槛,简化了表单创建过程。
本说明书实施例还提供另一种基于JSON结构的表单创建方法流程示意图,如图2所示。在本实施例中,假设表单的应用场景为财务产品的报销单,要求以左边列表右边卡片的形式展示数据,左边列表只展示报销单编号、报销人、花费金额三列信息,选中列表某行后右边卡片中展示报销单详细信息。此外表单需要启用附件上传功能,从而将发票影像上传到系统中。创建此表单的实施步骤如下:
首先,选择表单模型。报销单的表单类型为左列表右卡片类页面,因此在向导第一步中选择左列表右卡片界面模板。
在选择表单模板后,选择数据模型。确定报销单对应的数据库表信息,选择后台预置的报销单数据表,本发明会将报销单表信息转换为实体模型。以下为截取的部分实体JSON数据:
之后,选择表单展示字段。在界面中勾选列表显示字段:报销单编号、报销人、花费金额三个字段;勾选卡片显示字段:报销单编号、报销日期、报销人、花费金额、报销部门、报销单备注等字段。本发明会将列表展示字段生成列表的列,而卡片显示字段则根据字段定义的控件类型分别生成文本控件、日期控件、文本控件、数字控件、文本控件、多行文本控件。生成的控件JSON放在了组件模型中。
判断是否需要使用表单的高级特性,若不需要,则完成表单创建,若需要使用表单的高级特性,则选择表单高级特性。在本说明书的实施例中,报销单需要启用附件上传功能,从而将发票影像上传到系统中,因此,勾选附件上传特性。勾选后将创建一份附件控件的JSON结构,并放在表单组件模型中,此外还将在视图模型中预设附件上传的命令。
本说明书实施例还提供一种基于JSON结构的表单创建设备,如图3所示,包括:至少一个处理器;以及与至少一个处理器通信连接的存储器;其中,存储器存储有可被至少一个处理器执行的指令,指令被至少一个处理器执行,以使至少一个处理器能够:根据表单的使用类型选择对应的表单模板,其中,表单模板使用JSON结构进行描述,表单模板的JSON结构包括:数据实体模型、组件模型和视图模型;根据表单的使用场景选择对应的表单数据实体模型,其中,表单数据实体模型包括字段信息;根据使用场景选择表单展示的字段信息,以用于确定表单对应的组件模型和视图模型,并根据表单对应的组件模型和视图模型完成表单创建。
本说明书实施例采用的上述至少一个技术方案预先设置表单的JSON结构,根据表单的使用类型选择预先设置的表单模板,进一步根据使用场景确定与数据库对应的表单数据实体模型,用户选择待展示的字段信息后,生成对应的组件模型和视图模型,完成表单的创建,用户只需选择表单模板、数据库表以及待展示的字段便可以完成表单的操作,降低了操作难度和用户的使用门槛,用户可以通过直观、简单的前端界面完成表单的创建,简化了表单创建过程。
本说明书中的各个实施例均采用递进的方式描述,各个实施例之间相同相似的部分互相参见即可,每个实施例重点说明的都是与其他实施例的不同之处。尤其,对于装置、设备、非易失性计算机存储介质实施例而言,由于其基本相似于方法实施例,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
上述对本说明书特定实施例进行了描述。其它实施例在所附权利要求书的范围内。在一些情况下,在权利要求书中记载的动作或步骤可以按照不同于实施例中的顺序来执行并且仍然可以实现期望的结果。另外,在附图中描绘的过程不一定要求示出的特定顺序或者连续顺序才能实现期望的结果。在某些实施方式中,多任务处理和并行处理也是可以的或者可能是有利的。
以上所述仅为本说明书的一个或多个实施例而已,并不用于限制本说明书。对于本领域技术人员来说,本说明书的一个或多个实施例可以有各种更改和变化。凡在本说明书的一个或多个实施例的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本说明书的权利要求范围之内。
Claims (10)
1.一种基于JSON结构的表单创建方法,其特征在于,所述方法包括:
根据所述表单的使用类型选择对应的表单模板,其中,所述表单模板使用JSON结构进行描述,所述表单模板的JSON结构包括:数据实体模型、组件模型和视图模型;
根据所述表单的使用场景选择对应的表单数据实体模型,其中,所述表单数据实体模型包括字段信息;
根据所述使用场景选择所述表单展示的所述字段信息,以用于确定所述表单对应的组件模型和视图模型,并根据所述表单对应的组件模型和视图模型完成所述表单创建。
2.根据权利要求1所述的一种基于JSON结构的表单创建方法,其特征在于,所述根据所述表单使用类型选择对应的表单模板之前,所述方法还包括:
预置多种类型的表单模板,其中,所述表单模板的类型包括列表界面模板、双列表界面模板、卡片界面模板、左列表右卡片界面模板、树表界面模板、左树右卡片界面模板、左树右列表界面模板、批量编辑列表界面模板、向导界面模板以及滚动定位卡片界面模板中的一项或多项。
3.根据权利要求1所述的一种基于JSON结构的表单创建方法,其特征在于,所述根据所述表单的使用场景选择对应的表单数据实体模型,具体包括:
根据所述表单的使用场景选择所述表单对应的数据库表;
预先将所述数据库表转化为对应的所述表单数据实体模型,以便于根据用户选择的所述数据库表,选择所述数据库表对应的表单数据实体模型。
4.根据权利要求2所述的一种基于JSON结构的表单创建方法,其特征在于,所述字段信息包括:字段类型以及字段对应的表单控件类型;
所述根据使用场景选择表单展示的所述表单数据实体模型中的字段信息,具体包括:
根据所述表单的使用场景,选择待展示的字段;
根据所述待展示的字段的字段信息确定所述表单的表单控件类型,并生成对应的控件JSON结构。
5.根据权利要求4所述的一种基于JSON结构的表单创建方法,其特征在于,所述根据所述待展示的字段的字段类型确定所述表单的表单控件类型,并生成对应的控件JSON结构,具体包括:
当用户选择的待展示的字段的字段类型为数字类型时,确定所述表单的表单控件类型为数字控件类型,并生成对应的数字控件JSON结构。
6.根据权利要求4所述的一种基于JSON结构的表单创建方法,其特征在于,所述确定所述表单对应的组件模型和视图模型,具体包括:
根据所述表单对应的表单模板的类型,将所述表单划分为至少一个组件区域,所述组件区域包括列表区域、卡片区域以及数表区域中的一项或多项;
将每个所述组件区域定义为对应的组件模型和视图模型,其中,所述组件模型与所述视图模型为一对一映射的关系;
将所述控件JSON结构设置在所述组件模型中,并在对应的所述视图模型中记录所述字段信息。
7.根据权利要求1所述的一种基于JSON结构的表单创建方法,其特征在于,所述表单模板的JSON结构还包括状态机模型,以用于控制表单运行时的状态切换,其中所述表单运行时的状态包括只读状态和编辑状态。
8.根据权利要求1所述的一种基于JSON结构的表单创建方法,其特征在于,所述完成表单创建之前,所述方法还包括:
根据用户需求预置所述表单的高级特性,其中,所述表单的高级特性包括以下一项或多项:启用审批工作流程、启用数据导入导出以及启用附件上传下载。
9.根据权利要求8所述的一种基于JSON结构的表单创建方法,其特征在于,所述根据用户需求预置所述表单的高级特性,具体包括:
根据用户需求确定所述表单的高级特性的类型,基于所述高级特征的类型在所述组件模型中添加对应的组件,并在所述视图模型中添加对应的命令,生成与所述高级特性相关的JSON结构。
10.一种基于JSON结构的表单创建设备,其特征在于,包括:
至少一个处理器;以及,
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够:
根据所述表单的使用类型选择对应的表单模板,其中,所述表单模板使用JSON结构进行描述,所述表单模板的JSON结构包括:数据实体模型、组件模型和视图模型;
根据所述表单的使用场景选择对应的表单数据实体模型,其中,所述表单数据实体模型包括字段信息;
根据所述使用场景选择所述表单展示的所述字段信息,以用于确定所述表单对应的组件模型和视图模型,并根据所述表单对应的组件模型和视图模型完成所述表单创建。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110983930.3A CN113760287A (zh) | 2021-08-25 | 2021-08-25 | 一种基于json结构的表单创建方法及设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202110983930.3A CN113760287A (zh) | 2021-08-25 | 2021-08-25 | 一种基于json结构的表单创建方法及设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN113760287A true CN113760287A (zh) | 2021-12-07 |
Family
ID=78791269
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202110983930.3A Pending CN113760287A (zh) | 2021-08-25 | 2021-08-25 | 一种基于json结构的表单创建方法及设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN113760287A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114327463A (zh) * | 2021-12-31 | 2022-04-12 | 浙江吉利控股集团有限公司 | 网页表单自动生成方法、装置、介质、设备及程序产品 |
CN114428771A (zh) * | 2021-12-29 | 2022-05-03 | 北京明易达科技股份有限公司 | 基于表单设计的通用数据库模型生成方法、装置和设备 |
CN116627418A (zh) * | 2023-07-21 | 2023-08-22 | 之江实验室 | 一种基于递归算法的多级表单界面可视化生成方法及装置 |
-
2021
- 2021-08-25 CN CN202110983930.3A patent/CN113760287A/zh active Pending
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114428771A (zh) * | 2021-12-29 | 2022-05-03 | 北京明易达科技股份有限公司 | 基于表单设计的通用数据库模型生成方法、装置和设备 |
CN114428771B (zh) * | 2021-12-29 | 2023-09-15 | 北京明易达科技股份有限公司 | 基于表单设计的通用数据库模型生成方法、装置和设备 |
CN114327463A (zh) * | 2021-12-31 | 2022-04-12 | 浙江吉利控股集团有限公司 | 网页表单自动生成方法、装置、介质、设备及程序产品 |
CN116627418A (zh) * | 2023-07-21 | 2023-08-22 | 之江实验室 | 一种基于递归算法的多级表单界面可视化生成方法及装置 |
CN116627418B (zh) * | 2023-07-21 | 2023-10-03 | 之江实验室 | 一种基于递归算法的多级表单界面可视化生成方法及装置 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7885868B2 (en) | Reading, organizing and manipulating accounting data | |
CN113760287A (zh) | 一种基于json结构的表单创建方法及设备 | |
US20030204637A1 (en) | Method and apparatus for generating compilable application programs | |
CN114564252A (zh) | 一种低代码平台的事件配置方法、系统、设备及介质 | |
CN104182225A (zh) | 一种通用移动信息系统适配方法与装置 | |
CN107562710B (zh) | 一种图表处理装置及方法 | |
US20070294631A1 (en) | Apparatus and method for embedding and utilizing report controls within an online report | |
Hurst | Hands on with Google Data Studio: A Data Citizen's Survival Guide | |
Read et al. | Spreadsheet modelling best practice | |
CN116956847B (zh) | 报表管理方法和装置 | |
CN115048396A (zh) | 账单处理方法及装置 | |
US10282407B1 (en) | Method for filtering data to generate a balance sheet | |
Day | Mastering financial modelling | |
Oluwa | Hands-On Financial Modeling with Microsoft Excel 2019: Build practical models for forecasting, valuation, trading, and growth analysis using Excel 2019 | |
Ahammad | iReport 3.7 | |
McFedries | Formulas and functions with Microsoft Office Excel 2007 | |
Korol | Excel 2021/Microsoft 365 Programming By Example | |
CN113052675B (zh) | 数据展示方法和装置 | |
Aguillard | Xero: A Comprehensive Guide for Accountants and Bookkeepers | |
CN118467597A (zh) | 数据填报显示方法、装置、电子设备及存储介质 | |
Hsiao | Economic and business analysis: quantitative methods using spreadsheets | |
Mahmoud | Learning SAP BusinessObjects Dashboards | |
CN116956851A (zh) | 表单生成方法、装置、电子设备及存储介质 | |
CN117290620A (zh) | 一种显示方法和装置 | |
Renders | Microsoft Dynamics NAV 2015 Professional Reporting |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |