关于我对表单设计的一点思考—自动化生成表单

简介: 关于我对表单设计的一点思考—自动化生成表单

之前在练习React+Antd时写了几个表单的小Demo,本文总结一下有关表单及组件设计方面的思考


image.png

比如我们在自动生成这个表单组件的时候,虽然功能和字段不是很多,但是我们应该怎么设计出一个合理的结构,才是一个值得思考的问题。


state数据结构的设计



我们知道React是单向数据流,并且是数据驱动。设计好一个数据结构,是我们关键的一步。

首先,我们应该思考,怎么用数据来描述我们的页面。第二步,我们的数据要结构化,易于我们遍历,查找和自动生成相应的视图。第三步,也就是扩展性,假如这个表单要加入新的字段,或者修改某个字段,如何更加的方便快捷。


开始设计


这个表单有四个字段,每个字段就相当于一个key-value的结构,所以我们的数据部分可以设计成为一个对象,采用key-value的形式。


const value = {
    '连接地址':'xxx',
    '端口号','xxx',
    '用户名':'xxx',
    '密码':'xxx',
}


扩充


刚刚只是我们的第一步,一般我们填写表单的时候,都有对应的规则信息,如果不满足相应的规则,我们是提交不成功的。那么我们怎么设置表单的规则呢?


如果我们在数据部分去加相应的信息,value里面的信息就很冗余和复杂。我们可以专门设置一个字段来限定每个字段相应的属性,并且还可以在字段里面添加默认值,相应的类型


[
    {
        "label": "连接地址",
        "defaultValue": "192.168.0.1",
        "field": "addr",
        "type": "string",
        "required": "true"
    },
    {
        "label": "端口号",
        "defaultValue": "21",
        "field": "port",
        "type": "string",
        "required": "true"
    },
    {
        "label": "用户名",
        "defaultValue": "user",
        "field": "userName",
        "type": "string",
        "required": "true"
    },
    {
        "label": "密码",
        "defaultValue": "password",
        "field": "password",
        "type": "string",
        "required": "true"
    }
]


我们可以用label字段表示相应的字段名,通过field来将每个字段的限制规则和相应的数据对应起来。我们将原来的value数据也完善一下

"value": {
        "password": "123456",
        "port": "24",
        "addr": "192.168.0.1",
        "userName": "admin"
    },


然后我们就可以根据这个完整的数据来自动渲染表单了

{
    "value": {
        "password": "123456",
        "port": "24",
        "addr": "192.168.0.1",
        "userName": "admin"
    },
    "formContent": "[{"label":"连接地址","defaultValue":"192.168.0.1","field":"addr","type":"string","required":"true"},{"label":"端口号","defaultValue":"21","field":"port","type":"string","required":"true"},{"label":"用户名","defaultValue":"user","field":"userName","type":"string","required":"true"},{"label":"密码","defaultValue":"password","field":"password","type":"string","required":"true"}]"
}


Antd_Form



看了下Antd表单组件的设计,它将一个Form拆分出了Form和Form.item


image.png


image.png


为什么要这么拆分呢?


我们在设计一个组件的时候,需要从功能上拆分层次,尽量让组件原子化,只干一件事情。还可以让容器组件(只管理数据)和渲染组件(只管理视图)进行分离

通过Form表单的Api,我们可以发现,Form组件可以控制宏观上的布局,整个表单的样式和数据收集。Form.item控制每个字段的校验等。

也不知道对不对,就先这么记录一下 我的表单实现:表单demo练习


目录
相关文章
|
开发者
入职自动化的案例背景和表单搭建|学习笔记
快速学习入职自动化的案例背景和表单搭建
入职自动化的案例背景和表单搭建|学习笔记
|
2月前
|
机器学习/深度学习 人工智能 运维
构建高效运维体系:从自动化到智能化的演进
本文探讨了如何通过自动化和智能化手段,提升IT运维效率与质量。首先介绍了自动化在简化操作、减少错误中的作用;然后阐述了智能化技术如AI在预测故障、优化资源中的应用;最后讨论了如何构建一个既自动化又智能的运维体系,以实现高效、稳定和安全的IT环境。
77 4
|
2月前
|
运维 Linux Apache
,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具
【10月更文挑战第7天】随着云计算和容器化技术的发展,自动化运维成为现代IT基础设施的关键部分。Puppet是一款强大的自动化运维工具,通过定义资源状态和关系,确保系统始终处于期望配置状态。本文介绍Puppet的基本概念、安装配置及使用示例,帮助读者快速掌握Puppet,实现高效自动化运维。
65 4
|
23天前
|
机器学习/深度学习 运维 监控
智能化运维:从自动化到AIOps的演进之路####
本文深入探讨了IT运维领域如何由传统手工操作逐步迈向高度自动化,并进一步向智能化运维(AIOps)转型的过程。不同于常规摘要仅概述内容要点,本摘要将直接引入一个核心观点:随着云计算、大数据及人工智能技术的飞速发展,智能化运维已成为提升企业IT系统稳定性与效率的关键驱动力。文章详细阐述了自动化工具的应用现状、面临的挑战以及AIOps如何通过预测性分析和智能决策支持,实现运维工作的质变,引领读者思考未来运维模式的发展趋势。 ####
|
23天前
|
机器学习/深度学习 数据采集 人工智能
智能化运维:从自动化到AIOps的演进与实践####
本文探讨了智能运维(AIOps)的崛起背景,深入分析了其核心概念、关键技术、应用场景及面临的挑战,并对比了传统IT运维模式,揭示了AIOps如何引领运维管理向更高效、智能的方向迈进。通过实际案例分析,展示了AIOps在不同行业中的应用成效,为读者提供了对未来智能运维趋势的洞察与思考。 ####
55 1
|
1月前
|
机器学习/深度学习 数据采集 人工智能
智能运维:从自动化到AIOps的演进与实践####
本文探讨了智能运维(AIOps)的兴起背景、核心组件及其在现代IT运维中的应用。通过对比传统运维模式,阐述了AIOps如何利用机器学习、大数据分析等技术,实现故障预测、根因分析、自动化修复等功能,从而提升系统稳定性和运维效率。文章还深入分析了实施AIOps面临的挑战与解决方案,并展望了其未来发展趋势。 ####
|
1月前
|
机器学习/深度学习 数据采集 运维
智能化运维:机器学习在故障预测和自动化响应中的应用
智能化运维:机器学习在故障预测和自动化响应中的应用
60 4
|
2月前
|
运维 jenkins 持续交付
自动化部署的魅力:如何用Jenkins和Docker简化运维工作
【10月更文挑战第7天】在现代软件开发周期中,快速且高效的部署是至关重要的。本文将引导你理解如何使用Jenkins和Docker实现自动化部署,从而简化运维流程。我们将从基础概念开始,逐步深入到实战操作,让你轻松掌握这一强大的工具组合。通过这篇文章,你将学会如何利用这些工具来提升你的工作效率,并减少人为错误的可能性。
|
2月前
|
运维 Prometheus 监控
运维中的自动化实践每月一次的系统维护曾经是许多企业的噩梦。不仅因为停机时间长,更因为手动操作容易出错。然而,随着自动化工具的引入,这一切正在悄然改变。本文将探讨自动化在IT运维中的重要性及其具体应用。
在当今信息技术飞速发展的时代,企业对系统的稳定性和效率要求越来越高。传统的手动运维方式已经无法满足现代企业的需求。自动化技术的引入不仅提高了运维效率,还显著降低了出错风险。本文通过几个实际案例,展示了自动化在IT运维中的具体应用,包括自动化部署、监控告警和故障排除等方面,旨在为读者提供一些实用的参考。
下一篇
DataWorks