基于React实现 动态表单 (一)

       这里实现动态表单功能,是为了应对大量表单提交的业务。跟问卷调查比较像,每次都有各种问题要收集,按道理,每次来不同的问卷都要重新开发一次前后端代码,虽然这个不是很麻烦,但这种需求业务逻辑并不复杂,是可以做成公共功能的,所以想实现这个动态表单功能,来了新需求,直接在界面设计好,然后分享生成的二维码或者链接给填报对象,所以这个主要是开发给业务人员用的,不需要会代码也可以完成要求。

假如我现在有个需求:

        初中毕业十周年了,需要组织一次同学聚会,需要先收集同学们的资料,需要收集的信息有(姓名、性别、联系电话、工作地点、工作单位、从事行业、微信号、生活照)

我现在有一个动态表单设计系统:

通过新建表单界面,根据收集信息的字段,要用什么组件去展示,直接从左边开发好的组件中选择,然后组件名字改成对应收集字段的名字。最右边设置好表单信息,用于表单展示及最后作为表名。表单创建好后,可以分享链接给需要填报的同学。

手机端填报界面:

设置了必填的字段前面会有一个红*,在提交的时候也会根据不同类型组件去校验:

比如这联系方式,设计的时候选择了手机号类型,提交的时候就会按手机号的格式去校验(基本每个组件都有自己的校验规则):

填报成功后,可以对所有同学填报的信息进行管理:

最后可以导出所有同学填报的数据:

所以,这个动态表单功能,只要是表单提交的业务需求,灵活性是很高的。不管什么业务,只要是表单提交,你也不需要会写代码,会用这么个系统就好了。

开发此动态表单的技术点:

前端: React + umi2 + antd + antd-mobile + Dva + ES6

后端: Springboot + Maven + MySQL + Linux + Redis

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
好的,我可以帮您解答这个问题。基于Ant Design React,您可以使用Table组件来实现一个可动态添加和编辑表格内容的表格。 首先,您需要在代码中引入Table组件: ``` import { Table } from 'antd'; ``` 然后,您需要定义表格的列和数据源。您可以将这些数据定义为组件的state,以便在添加和编辑表格内容时进行更新。例如: ``` state = { columns: [ { title: '姓名', dataIndex: 'name', key: 'name', }, { title: '年龄', dataIndex: 'age', key: 'age', }, { title: '地址', dataIndex: 'address', key: 'address', }, ], data: [ { key: '1', name: 'John Brown', age: 32, address: 'New York No. 1 Lake Park', }, { key: '2', name: 'Jim Green', age: 42, address: 'London No. 1 Lake Park', }, ], }; ``` 接下来,您需要在render方法中使用Table组件来渲染表格,并将列和数据源传递给它。例如: ``` <Table columns={this.state.columns} dataSource={this.state.data} /> ``` 现在,您可以使用Ant Design的Form组件来实现添加和编辑表格内容的功能。您可以为表格添加一个“添加”按钮,单击该按钮可以弹出一个包含表单的模态框。用户可以在表单中输入新的行数据,然后单击“确定”按钮将新的行添加到表格中。 您还可以为表格的每一行添加一个“编辑”按钮。单击该按钮可以弹出一个包含表单的模态框,并自动填充该行的数据。用户可以在表单中编辑行数据,然后单击“确定”按钮将更新后的行数据保存到表格中。 最后,为了实现动态添加表格内容的功能,您需要在“添加”按钮单击事件中更新数据源state。例如: ``` handleAdd = () => { const { data } = this.state; const newData = { key: data.length + 1, name: `Edward King ${data.length + 1}`, age: 32, address: `London, Park Lane no. ${data.length + 1}`, }; this.setState({ data: [...data, newData], }); }; ``` 这样,您就可以实现一个基于Ant Design React的可动态添加和编辑表格内容的表格了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值