一、表单元素操作事项

1、form 默认在prop中存在:this.props.form,直接使用即可

2、重置:this.props.form.resetFields();

3、赋值:form.setFieldsValue({ categoryId: select });

4、取值校验:

    e.preventDefault();
this.props.form.validateFields((err, values) => {
if (!err) {
dispatch({
type: 'codeSync/actionRecycleInfo',
payload: values,
callback: response => {
this.showChangeAction(response);
},
});
}
});

二、state赋值

1、普通赋值:  this.setState({ huanjieData: response.data });

2、对象追加值:

     this.setState(
Object.assign(this.state.changeData, { ...data }),
() => {
console.log(11, this.state);
},
);

关于:Object.assign,可以参看:https://www.cnblogs.com/bjlhx/p/10288760.html

3、父子组件传输state

import React, { PureComponent, Fragment } from 'react';
import { connect } from 'dva';
import moment from 'moment';
import {
Row,
Col,
Card,
Form,
Input,
Button,
Modal,
message,
Badge,
Dropdown,
Menu,
Icon,
Select,
Table,
Divider,
Tag,
Radio,
} from 'antd';
import styles from './SyncCode.less'; const FormItem = Form.Item;
const RadioGroup = Radio.Group;
const { Option } = Select;
const { TextArea } = Input; // 批次数据新增弹层
const SyncCodeChangeTraceAccount = Form.create()(props => {
//接收父类参数
const { showVisible, changeGetHuanJie, handleCategory, form, handleVisibleAction, itemData,huanjieData, templates } = props; // 创建批次确定提交功能
const okHandleAdd = () => {
alert('提交表单:' + JSON.stringify(itemData));
}; const onChangeTraceAccount = e => {
const traceAccount = event.target.value;
if (itemData.dataProvideTraceAccount == traceAccount) {
message.error('替换供应商不能是当前账号');
event.target.value = '';
} else {
//获取 模板
const trace = { traceAccount: traceAccount };
const select = handleCategory(trace);
//select 参数组装
form.setFieldsValue({ categoryId: select });
changeGetHuanJie({ traceAccount: traceAccount, syncType: 2, categoryId: null });
}
}; const onChangeCategoryId = (value, options) => {
changeGetHuanJie({ categoryId: value });
}; const onChangeBatch = event => {
changeGetHuanJie({ batchCode: event.target.value });
}; return (
<Modal
destroyOnClose
title="变更追溯环节"
onOk={okHandleAdd}
visible={showVisible}
// className={styles.batc、hModel}
onCancel={() => handleVisibleAction()}
width="80%"
okText="确认变更"
>
<Table
columns={columns2}
dataSource={huanjieData}
rowKey="dataType"
locale={{ emptyText: '暂无数据' }}
pagination={false}
/>
</Modal>
);
}); @connect(({ codeSync, loading }) => ({
codeSync,
// loading: loading.models.sweepcode,
}))
@Form.create()
class SyncCode extends PureComponent {
// 初始化状态值
state = {
huanjieData: [],
}; // 改变 获取环节信息
changeGetHuanJie = data => {
return this.handleHuanJie(data);
};
handleHuanJie = (changeData) => {
const { dispatch } = this.props;
dispatch({
type: 'codeSync/actionQueryTacheList',
payload: changeData,
callback: response => {
if (response.code == 20000) {
this.setState({ huanjieData: response.data });
} else {
Modal.error({
title: '查询失败',
content: response.msg,
});
}
},
}
}; // 渲染批次数据列表界面
render() {
const {
form: { getFieldDecorator },
} = this.props; const {huanjieData, itemData,changeVisible} = this.state;
//传输 父类方法到子类
const parentMethods = {
changeGetHuanJie: this.changeGetHuanJie,
handleCategory: this.handleCategory,
handleVisibleAction: this.showChangeAction,
}; return (
<div style={{ background: '#ECECEC', padding: '30px' }}>
<Table
{...parentMethods}
itemData={itemData}
huanjieData={huanjieData}
showVisible={changeVisible}
/>
</div>
);
}
} export default SyncCode;

过程:子类方法onChangeCategoryId控制父类方法changeGetHuanJie操作state,state设置了huanjieData,会通过组件定义绑定时候传输过去

子类不要有太多操作。

002-pro ant design 表单基本使用、state赋值数据父子传输的更多相关文章

  1. Ant Design 表单中getFieldDecorator、getFieldValue、setFieldValue用法

    Ant Design 表单中getFieldDecorator.getFieldValue.setFieldValue用法 一.getFieldDecorator getFieldDecorator是 ...

  2. 如何实现Ant design表单组件封装?

    目标:自己实现一个antd表单组件 先看下Ant Design官网上给出的表单组件用法: import React, { Component } from 'react' import { Form, ...

  3. ant Design表单验证笔记

    1.pattern正则验证 <Col md={12} sm={24}> <FormItem {...formItemLayout} label="班数"> ...

  4. ant design pro (十六)advanced 权限管理

    一.概述 原文地址:https://pro.ant.design/docs/authority-management-cn 权限控制是中后台系统中常见的需求之一,你可以利用我们提供的权限控制组件,实现 ...

  5. ant design pro (十三)advanced 错误处理

    一.概述 原文地址:https://pro.ant.design/docs/error-cn 二.详细 2.1.页面级报错 2.1.1.应用场景 路由直接引导到报错页面,比如你输入的网址没有匹配到任何 ...

  6. Ant Design Pro入门教程,安装,运行(V5 Typescript版)

    [前言] 找了很多Admin模板,最后还是看中了AntDesignPro这个阿里巴巴开源的Admin框架,长这样(还行吧,目前挺主流的): 官网地址:https://pro.ant.design/in ...

  7. ANT DESIGN PRO 脚手架.... 懒人福音

    早上在用蚂蚁组件,看到一个红红的 PRO , 什么鬼,点了看. https://pro.ant.design/index-cn 一脸懵逼, 中台前端??? 预览再看: 后台管理的demo , 脚手架  ...

  8. 阿里开源项目之Ant Design Pro

    本篇文章主要包含的内容有三个方面. 第一.Ant Design Pro简介; 第二.Ant Design Pro能做什么; 第三.初步使用; 我相信通过这三个方面的讲解能让你大概知道Ant Desig ...

  9. ant design pro (十五)advanced 使用 API 文档工具

    一.概述 原文地址:https://pro.ant.design/docs/api-doc-cn 在日常开发中,往往是前后端分离的,这个时候约定好一套接口标准,前后端各自独立开发,就不会被对方的技术难 ...

随机推荐

  1. [Laravel] 07 - Project: functions in Controller

    故事背景 一.项目预览 From: https://www.imooc.com/video/12521 表单操作 一.新增信息 既然是操作,自然会想到:控制器. 控制器  [1] 路由 ----> ...

  2. Linux设备驱动剖析之IIC(二)

    953行,适配器的编号大于MAX_ID_MASK是不行的,MAX_ID_MASK是一个宏,展开后的值为61. 957至968行,关于管理小整形ID数的,没怎么了解,略过. 974行,调用i2c_reg ...

  3. 【zheng阅读系列】shiro权限管理

    一.配置文件 upms-server/springMVC-servlet.xml <?xml version="1.0" encoding="UTF-8" ...

  4. Arduino基本数据类型

    基本数据类型简介 常见的Arduino是基于ATmega的8位 AVR单片机,例如Arduino UNO ,Arduino Nano,Arduino mega2560等.还有高级点 32位的,如Ard ...

  5. iOS - 富文本直接设置文字的字体大小和颜色

    富文本效果图: 富文本实现代码: UILabel *orderSureLabel = [Common lableFrame:CGRectZero title:] textColor:[UIColor ...

  6. Django之Web框架本质及第一个Django实例

    Web框架本质 我们可以这样理解:所有的Web应用本质上就是一个socket服务端,而用户的浏览器就是一个socket客户端. 这样我们就可以自己实现Web框架了. 半成品自定义web框架 impor ...

  7. String对象的比较

    public class StringTest { /* * equals 和 ==的区别 * 如果类中没有重写equals(),那么默认比较也是内存地址 * ==在基本数据类型中比较的是值! * i ...

  8. 强大的Android基地 论坛

    强大的Android基地 论坛 [非常值得推荐,需要的自己动手去看...] 地址:http://www.eoeandroid.com/forum-15-1.html 大家论坛:http://club. ...

  9. Docker容器集群管理之Swarm

    Docker容器集群管理主流方案 Swarm Docker公司自研发的集群管理系统. Kubernetes Google开源的一个容器集群管理系统,用于自动化部署.扩展和管理容器应用.也称为K8S ...

  10. PAT甲级1055 The World's Richest【排序】

    题目:https://pintia.cn/problem-sets/994805342720868352/problems/994805421066272768 题意: 给定n个人的名字,年龄和身价. ...