动态表单设计

3 篇文章 0 订阅
2 篇文章 0 订阅

背景

实现动态表单功能,支持表单自定义并实现后期的数据统计、分析。
在这里插入图片描述

方案讨论
  • 一 、基于非结构化的Json。
    • 优点:通过NoSql的mongdb存储可以减少json解析的复杂度及资源损耗,可以提高效率。
    • 缺点:非结构化的Json,模板定义和表单数据值存在一起,后期的数据分析非常困难。解决不了非结构化数据分析的根本问题。
{
        "item": [
            {
                "repeats": 0,
                "childType": "text",
                "itemType": 1,
                "updateDate": "1619599422000",
                "max": 0,
                "prefix": "1",
                "readOnly": 0,
                "optionRepeats": 0,
                "qtId": "584824102494277632",
                "sectionId": "584824208362704896",
                "type": "string",
                "required": 0,
                "itemId": "569271103424434176",
                "score": 0,
                "sequence": 1,
                "configRes": {
                    "childType": "text",
                    "configContent": "{\"childType\":\"text\",\"max\":0,\"showTypeName\":\"¶àÐÐÎı¾Ìâ\",\"typeName\":\"×Ö·û´®\",\"characterLimit\":\"none\",\"textType\":\"string\",\"type\":\"string\",\"categoryName\":\"ÎÒµÄÌâ¿â\",\"min\":0,\"showType\":\"text\",\"id\":\"569271103424434176\",\"text\":\"ÐÕÃû\",\"categoryId\":\"1371773393070960641\"}",
                    "textType": "string",
                    "characterLimit": "none"
                },
                "linkId": "ab108b9f-86ae-43c7-885c-9eb3de2935e9",
                "min": 0,
                "showType": "text",
                "sectionItemRId": "1387326646303043586",
                "id": "1387326646303043586",
                "text": "ÐÕÃû",
                "createDate": "1619599422000",
                "status": 1
            },
            {
                "repeats": 0,
                "arrayType": "1",
                "itemType": 1,
                "updateDate": "1619599422000",
                "prefix": "2",
                "readOnly": 0,
                "optionRepeats": 0,
                "qtId": "584824102494277632",
                "sectionId": "584824208362704896",
                "type": "choice",
                "required": 0,
                "itemId": "569271034725928960",
                "score": 0,
                "sequence": 2,
                "configRes": {
                    "configContent": "{\"arrayType\":\"1\",\"optionValue\":\"ÄÐ | Å®\",\"showTypeName\":\"µ¥Ñ¡Ìâ\",\"optionList\":[{\"defaultStatus\":\"0\",\"itemId\":\"569271034725928960\",\"sequence\":1,\"code\":\"0\",\"detailedStatus\":\"0\",\"display\":\"ÄÐ\",\"itemOptionId\":\"569271034797232128\"},{\"defaultStatus\":\"0\",\"itemId\":\"569271034725928960\",\"sequence\":2,\"code\":\"1\",\"detailedStatus\":\"0\",\"display\":\"Å®\",\"itemOptionId\":\"569271034797232129\"}],\"typeName\":\"Ñ¡Ôñ\",\"showType\":\"choice\",\"id\":\"569271034725928960\",\"text\":\"ÐÔ±ð\",\"type\":\"choice\",\"categoryName\":\"ÎÒµÄÌâ¿â\",\"categoryId\":\"1371773393070960641\"}"
                },
                "linkId": "2ddd6ba5-394b-4634-9802-099ce64eb3b0",
                "showType": "choice",
                "sectionItemRId": "1387326646324015106",
                "id": "1387326646324015106",
                "text": "ÐÔ±ð",
                "createDate": "1619599422000",
                "option": [
                    {
                        "value": {
                            "defaultStatus": "0",
                            "code": "0",
                            "detailedStatus": "0",
                            "display": "ÄÐ",
                            "itemOptionRId": "584824208413036544"
                        }
                    },
                    {
                        "value": {
                            "defaultStatus": "0",
                            "code": "1",
                            "detailedStatus": "0",
                            "display": "Å®",
                            "itemOptionRId": "584824208429813760"
                        }
                    }
                ],
                "status": 1
            },
            {
                "repeats": 0,
                "itemType": 1,
                "updateDate": "1619599422000",
                "prefix": "3",
                "type": "integer",
                "required": 0,
                "score": 0,
                "min": 0,
                "showType": "text",
                "id": "1387326646361763842",
                "text": "ÄêÁä",
                "createDate": "1619599422000",
                "childType": "number",
                "max": 0,
                "readOnly": 0,
                "optionRepeats": 0,
                "qtId": "584824102494277632",
                "sectionId": "584824208362704896",
                "itemId": "569271835015909376",
                "sequence": 3,
                "configRes": {
                    "childType": "number",
                    "configContent": "{\"childType\":\"number\",\"max\":0,\"showTypeName\":\"¶àÐÐÎı¾Ìâ\",\"typeName\":\"ÊýÖµ\",\"isSlide\":\"0\",\"type\":\"integer\",\"categoryName\":\"ÎÒµÄÌâ¿â\",\"min\":0,\"showType\":\"text\",\"numericType\":\"1\",\"id\":\"569271835015909376\",\"text\":\"ÄêÁä\",\"decimal\":0,\"categoryId\":\"1371773393070960641\"}",
                    "numericType": "1"
                },
                "linkId": "566122e3-4fb3-4fcb-8b44-2288f4ed1eea",
                "sectionItemRId": "1387326646361763842",
                "decimal": 0,
                "status": 1
            }
        ],
        "linkId": "982cb230-5381-419a-83af-916f66392824",
        "sectionId": "584824208362704896",
        "text": "·Ö×é1",
        "type": "group"
    }
  • 二 、基于jeecg/ruoyi-低代码开发平台
    • 比较固定的样式 和表定义
    • 针对自己需求坐二次开发改动较大
    • 表比较多涉及功能广,跟原需求出入较大,不好扩展。
基于上面分析,对比调研,自定义动态表单
  • 自定一表单数据结构。
  • 内容展示如有必要行转列。
数据模型

在这里插入图片描述

表单详解
select * from jim_dynamic_form where form_name = '调研问卷A'; -- 表单-调研问卷A
select * from jim_form_data_type ; -- 表单-数据类型

select * from jim_form_column where form_id = 1; -- 表单-调研问卷A的定义

select * from jim_form_data where form_id = 1 and data_id = 1 ; -- 表单-调研问卷A的数据记录1

-- 表单数据统计
select 
(select data_value from jim_form_data_detail where data_id = t.data_id and column_id = 1) as `姓名`, 
(select data_value from jim_form_data_detail where data_id = t.data_id and column_id = 2) as `年龄`,
(select data_value from jim_form_data_detail where data_id = t.data_id and column_id = 3) as `性别`,
(select data_value from jim_form_data_detail where data_id = t.data_id and column_id = 4) as `出生日期`
 from jim_form_data t where t.form_id = 1 and t.data_id = 1 ;
(一) 表单模板:jim_dynamic_form

在这里插入图片描述

(二)表单数据类型:jim_form_data_type

在这里插入图片描述

(三)表单字段定义:jim_form_column

在这里插入图片描述

(四)表单数据记录:jim_form_data

在这里插入图片描述

(五)表单数据统计:jim_form_data_detail

在这里插入图片描述

自定一组件
  • 前端根据题目类型自定义组件
  • 后端根据题目类型用策略模式校验各种类型
总结
  • 这样有统计功能的简单动态问卷就可以了
  • 展示时可能某些场景需要行转列。
  • 大概估摸使用的话有可能jim_form_data_detail表的记录数比较大,后期再考虑数据或者表迁移或拆分。
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Java动态表单设计是一种基于Java技术的通过程序自动生成表单的方法。通过Java动态表单设计,可以避免手动开发表单的过程中重复性工作和出错,提高开发效率和质量。 Java动态表单设计可以采用不同的技术实现,例如使用JavaServer Pages(JSP)技术、JavaScript技术、Spring MVC框架等。其中,使用JSP技术可以通过在JSP页面中使用标签库(Tag Library)与JavaBean交互,生成表单页面。而使用JavaScript技术,则可以通过DOM操作和AJAX技术在客户端生成表单元素和动态验证表单数据。使用Spring MVC框架,可以通过表单模型和视图模型的转换,拥有更加高级的技术支持。 无论采用哪种技术,Java动态表单设计都需要具备以下几个特点:首先是解耦合。生成表单的过程应该与具体的业务逻辑解耦合,确保表单设计可以灵活地运用于不同的应用场景。其次是可扩展性。表单元素和业务逻辑应该可以在运行时动态添加或删除,以应对不同需求的变化。第三是可移植性。表单设计应该遵循面向对象的设计原则,使得模块可以在不同的应用程序和平台上重用,提高代码的重用性和可维护性。 总之,Java动态表单设计是一种基于Java技术的表单生成方式,它可以提高表单开发的效率、质量和可维护性,为各种应用场景提供方便快捷的表单设计解决方案。 ### 回答2: Java动态表单设计可以帮助开发人员实现动态生成表单,改变表单结构以及在运行时进行表单显示数据等操作。该技术可以在开发大型企业应用程序和网站时提高开发人员的生产效率,同时减少因表单变化而导致的代码累赘。 Java动态表单设计实现方法有很多种,比如利用开源的框架或是手动编写自定义代码。其中,开源框架的使用更加方便快捷,例如JavaServer Faces(JSF)、Struts和Spring等。这些框架均提供了许多组件,如文本框、下拉框、单选框等,可以用于动态生成表单。同时,它们也支持对表单的持久化、数据验证和数据绑定等功能,使得开发人员可以快速、轻松地实现复杂的表单功能。 另外,在设计动态表单时需要考虑到用户交互和界面设计,以提高用户体验。设计师应该遵循Web标准,使用Web交互设计设计表单布局和样式,减少用户对表单的混乱和疑惑。此外,还可以采用可扩展的表单模板,为不同的业务场景创建不同的表单模板,以适应不同的需求。 总之,Java动态表单设计可以使开发人员更高效、更灵活地实现表单功能。同时,也需要注意用户界面设计和操作的便捷性。这对于企业应用程序的开发成功至关重要。 ### 回答3: Java 动态表单设计是一种方便快捷地根据具体需求生成表单的方法。通过 Java 编程语言和相关的框架,开发者可以根据业务逻辑和用户需求设计动态表单,并将其自动生成,并注入进入业务系统。 Java 动态表单设计的优势包括: 1. 灵活性:动态表单设计可以根据具体业务需求进行自定义,提高业务系统的灵活性。 2. 可维护性:一旦动态表单设计完成,就可以方便地维护和更新,无需修改代码,提高了开发效率。 3. 可重复性:动态表单可以根据预先定义的模板进行生成,提高了表单生成的可重复性。 4. 支持复杂业务逻辑:可以为表单添加各种校验规则和验证逻辑,增加了系统的安全性和可靠性。 Java 动态表单设计主要使用的框架有 Struts、Spring MVC、JSF 等。这些框架都提供了丰富的组件库,方便开发者根据自己的需求来自定义表单设计。同时,Java 动态表单设计也需要考虑与数据库的集成和数据流转等方面的问题,以确保表单的生成可以无障碍地流入到业务系统中。 总之,Java 动态表单设计提高了表单的灵活性、可维护性和可重复性,增加了系统的安全性和可靠性。它需要开发者具有一定的 Java 编程经验和相关框架使用经验,同时需要考虑与业务系统的整合以及入库等问题。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值