import React from 'react';
import {Form, InputNumber, Input, DatePicker, Button, Select, Icon} from 'antd';
import moment from 'moment';
// 推荐在入口文件全局设置 locale
import 'moment/locale/zh-cn';
moment.locale('zh-cn'); import PageTitle from "component/page-title/PageTitle";
import AppBreadcrumb from "component/breadcrumb/AppBreadcrumb";
import './index.scss'; const FormItem = Form.Item;
const Option = Select.Option; // 后台返回的数据格式
const formData = [
{
'field': 'jobid',
'text': '工号',
'errorMessage': '请输入工号',
'required': true,
'type': 'int',
'value': 100
}, {
'field': 'date',
'text': '日期',
'errorMessage': '请输入日期',
'required': false,
'type': 'date',
'value': '2017-10-20'
}, {
'field': 'username',
'text': '用户名',
'errorMessage': '请输入用户名',
'required': true,
'type': 'char',
'value': 'hello world'
}, {
'field': 'customer',
'text': '客户',
'errorMessage': '请输入客户',
'required': true,
'type': 'select',
'value': '中兴',
'options': ['贝尔', '中兴', '烽火']
}
]; // formItem css 样式
const formItemLayout = {
labelCol: {
xs: {span: 24},
sm: {span: 6},
},
wrapperCol: {
xs: {span: 24},
sm: {span: 14},
}
}; // 保存按钮 css 样式
const tailFormItemLayout = {
wrapperCol: {
xs: {
span: 24,
offset: 0,
},
sm: {
span: 14,
offset: 6,
},
}
}; // form css 样式
const formLayout = {
width: 400,
marginTop: 100,
marginLeft: 'auto',
marginRight: 'auto'
};
let uuid = 0; class AntFormTemplate extends React.Component {
constructor(props) {
super(props);
this.state = {
showForm: true,
formNumber: []
};
this.addForm = this.addForm.bind(this);
this.removeForm = this.removeForm.bind(this);
this.handleSubmit = this.handleSubmit.bind(this);
} addForm() {
const formDataObj = {};
formDataObj['uuid' + uuid] = formData;
this.state.formNumber.push(formDataObj);
uuid++;
this.setState({
formNumber: this.state.formNumber
});
} removeForm(formArray) {
if (this.state.formNumber.length === 1) {
return;
}
this.setState({
formNumber: this.state.formNumber.filter(item => item !== formArray)
});
} handleSubmit(e) {
e.preventDefault();
let suffixes =[];
const formDataList = [];
this.props.form.validateFields((err, values) => {
if (!err) {
for (const key in values) {
if (values.hasOwnProperty(key)) {
values[key] = moment.isMoment(values[key]) ? values[key].format('YYYY-MM-DD') : values[key]
suffixes.push(key.split('_')[1]);
suffixes = Array.from(new Set(suffixes));
}
}
console.log('values:' + this.formDataFilter(formDataList, suffixes, values));
}
});
} formDataFilter(formDataList, suffixes, values) {
suffixes.forEach(function (item) {
const formdataObj = {};
for (const key in values) {
if (values.hasOwnProperty(key) && key.indexOf(item)!==-1) {
formdataObj[key.split('_')[0]] = values[key];
}
}
formDataList.push(formdataObj);
})
return formDataList;
}
/**
* 根据后台返回的 data 中 type 类型生成不同的组件
* @param item json
* @param Component
*/
switchItem(item) {
const type = item.type;
switch (type) {
case 'int':
return <InputNumber style={{width: '100%'}}/>;
break;
case 'char':
return <Input />;
break;
case 'date':
return <DatePicker style={{width: '100%'}}/>;
break;
case 'select':
return (
<Select>
{
item.options.map((option, index) => {
return (<Option key={index} value={option}>{option}</Option>)
})
}
</Select>
);
default:
return <Input />;
break;
}
} render() {
const {getFieldDecorator} = this.props.form;
const dynamicForm = (
<Form onSubmit={this.handleSubmit} className="form-layout">
{
this.state.formNumber.map((formArray, formIndex) => {
return (
<div key={'div_' + formIndex} className="form-number">
{
this.state.formNumber.length > 1 ?
<Button type="dashed" key={'btn_' + formIndex} onClick={() => this.removeForm(formArray)}>
<Icon key={'icon_' + formIndex} type="close">删除此组form表单数据</Icon>
</Button> : null
}
{
Object.keys(formArray).map(key => {
return (
formArray[key].map((item, index) => {
item.value = item.type === 'date' ? moment(item.value, 'YYYY-MM-DD') : item.value;
return (
<FormItem
key={formIndex + index}
{...formItemLayout}
label={item.text}
hasFeedback>
{getFieldDecorator(item.field + '_' + key, {
initialValue: item.value,
rules: [{
required: item.required,
message: item.errorMessage
}],
})(
this.switchItem(item)
)}
</FormItem>
)
})
)
})
}
</div>
)
})
}
<div className="form-number">
<Button type="dashed" onClick={this.addForm}>
<Icon type="plus"/>添加一组数据
</Button>
</div>
<div className="form-number">
<Button type="primary" htmlType="submit">提交</Button>
</div>
</Form>
);
return (
<div className="page-wrapper">
<AppBreadcrumb menu="主导航" submenu="多组表单form处理"/>
<PageTitle pageTitle="多组动态表单数据传输处理"/>
{dynamicForm}
</div>
);
};
}
const AntForm = Form.create()(AntFormTemplate);
export default AntForm

react antd form多组表单数据处理的更多相关文章

  1. antd form 自定义验证表单使用方法

    import React from 'react'; import classNames from 'classnames'; export default class FormClass exten ...

  2. jquery.form.js 让表单提交更优雅

    jquery.form.js 让表单提交更优雅.可以页面不刷新提交表单,比jQuery的ajax提交要功能强大. 1.引入 <script src="/src/jquery-1.9.1 ...

  3. <form> 标签 // HTML 表单 // from 表单转换成json 格式

    <form> 标签   // HTML 表单    // from 表单转换成json 格式 form 表单,对开发人员来说是在熟悉不过的了,它是页面与web服务器交互时的重要信息来源 表 ...

  4. [转] Form 表单数据处理 简单教程 formidable 使用心得

    入门,高手见笑 表单数据一种是get方式, 另一种是post 方式 1.get方式 对于get方式,node处理起来非常简单 如以下代码: var urlParsed = url.parse(requ ...

  5. javaWeb 中前端Form表单数据处理(手动拼json)

    在前端我们会用到最多的就是form表单提交数据,在form表单中有很多都是自动将数据传到后台,然后通过实体来接受的,但是有的时候我们就是需要在前端就拿到这个Form表单的数据,这是我们就可以自己讲数据 ...

  6. 基于React和Node.JS的表单录入系统的设计与实现

    一.写在前面 这是一个真实的项目,项目已经过去好久了,虽然很简单,但还是有很多思考点,跟随着笔者的脚步,一起来看看吧.本文纯属虚构,涉及到的相关信息均已做虚构处理, 二.背景 人活着一定要有信仰,没有 ...

  7. Ext.Form 自动填写表单内容

    前台: 表单必须含有name属性 if (action == 'edit' || action == 'show') { MyForm1.getForm().load({ url: '/data/cu ...

  8. 使用jquery.form.js提交表单上传文件

    方法: 1.formSerilize()  用于序列化表单中的数据,并将其自动整理成适合AJAX异步请求的URL地址格式. 2.clearForm()   清除表单中所有输入值的内容. 3.restF ...

  9. form + iframe 获取表单提交后返回的数据

    原理: submit 提交表单没有回调函数,但是可以用iframe来接收返回结果,最后进行格式转换就ok了: 原文地址: http://blog.csdn.net/simeng_1016/articl ...

随机推荐

  1. vim 设置 颜色值

    编辑~/.vimrc文件,添加 set t_Co=8 t_Co即terminal Color之意 注意,将 t_Co 设置为256 (或8以外的所有值) 时,mark 的显示不是很正常.

  2. Jenkins+maven+Tomcat+SVN一键自动打包部署应用到服务器

    今天请教了大神,终于把jenkins给搞明白了 现在做下笔记,防止自己老年痴呆又忘了怎么配置 (截图可能不够清晰,有不清楚的随时评论打call) 机器配置: 安装配置规划 机器 192.168.169 ...

  3. less本地环境输出hello-world

    在学任何东西之前, 我就是有个习惯, 先搞定这个东西最最简单的使用方法. 然后在 深入学习, 毫无疑问hello-world一直是那么简单. 准备环境 较新版的高级浏览器. WAMP环境. less. ...

  4. laravel command命令行

    生成类 为了创建一个新命令,你可以使用Artisan中的 command:make 命令生成一个骨架作为你的起点: 生成一个命令类 php artisan command:make FooComman ...

  5. python16_day03【集合、编码、函数、递归、内置函数】

    一.集合 集合是一个无序的,不重复的数据组合,它的主要作用如下: 去重,把一个列表变成集合,就自动去重了 关系测试,测试两组数据之前的交集.差集.并集等关系 #创建: s = {3,5,9,10} # ...

  6. Memcached基础介绍

    1.memcached是什么,有什么作用? )memcached是一个开源的.高性能的内存的缓存软件,从名称上看mem就是内存的意思,而cache就是缓存的意思. )memcached通过在事先规划好 ...

  7. LeetCode:数组中的第K个最大元素【215】

    LeetCode:数组中的第K个最大元素[215] 题目描述 在未排序的数组中找到第 k 个最大的元素.请注意,你需要找的是数组排序后的第 k 个最大的元素,而不是第 k 个不同的元素. 示例 1: ...

  8. UVALive 6906 A - Cluster Analysis

    思路:排个序,依次选就好了. #include <bits/stdc++.h> #define PB push_back #define MP make_pair using namesp ...

  9. java发送http请求和多线程

    0 概述 在写app后台的时候,需要调用另一个服务器上的算法服务,所以需要发送http请求来获取结果. 考虑到一个功能(比如智能中医)需要调用好几个接口(人脸识别,舌苔识别,饮食推荐),大部分时间花在 ...

  10. Mspec

    Machine.Specifications Machine.Specifications (MSpec) is a context/specification framework that remo ...