antd是蚂蚁金服推出的ui组件库,给我们在react项目开发中提供了大大的便利。但在使用的过程中,或多或少的会遇到一些问题,毕竟,用的是别人的东西,就得遵守别人的规则嘛!官方文档:https://ant.design/docs/react/introduce-cn

1. 国际化(中文化)

通过官方文档我们可以知道,很多组件如DatePicker、Modal等等默认的文本都是英文。如果是输入框的提示文字我们可以通过组件的placeholder属性来自定义;如果是模态框底部按钮的文字我们也可以通过模态框组件提供的cancelTextokText 等属性来自定义,那如果是时间插件弹出的日历选择里面的标题日期呢?又或是穿梭框的项数总计?诸如此类…



其实,我们只需要在需要中文化的组件外面包裹组件 <LocaleProvider></LocaleProvider>组件即可。

代码如下(以DatePicker为例,其他组件用法相同):


import React, {Component} from 'react';
import { LocaleProvider, DatePicker } from 'antd';
import zh_CN from 'antd/lib/locale-provider/zh_CN';
import 'moment/locale/zh-cn'; class MyComponent extends Component {
render() {
return (
&lt;div className='content'&gt;
&lt;LocaleProvider locale={zh_CN}&gt;
&lt;DatePicker /&gt;
&lt;/LocaleProvider&gt;
&lt;/div&gt;
)
}
}

如果我们需要全局配置中文,则只需要在最外层的 <App />组件外包裹 <LocaleProvider>组件即可。


ReactDOM.render(
&lt;LocaleProvider locale={zh_CN}&gt;
&lt;App /&gt;
&lt;/LocaleProvider&gt;,
document.getElementById('root')
);

如涉及到其他语言,详情参考官方说明文档:https://ant.design/components/locale-provider-cn/

2. 表单校验取值

当我们使用antd的表单组件时,不能使用传统的方式获取输入框或者其他表单组件的值了。这是,我们需要借助官方提供的getFieldDecorator 来获取表单的值。要得到getFieldDecorator的前提必须要先使用Form.create()创建表单。

代码如下:


import React, {Component} from 'react';
import {Row, Col, Form, Input, Button} from 'antd'; const FormItem = Form.Item; class MyForm extends Component {
getFormItemLayout = () =&gt; {
const formItemLayout = {
labelCol: {
xs: { span: 24 },
sm: { span: 6 },
},
wrapperCol: {
xs: { span: 24 },
sm: { span: 15 },
},
};
return formItemLayout;
}
render() {
const fields = this.props.fields;
const { getFieldDecorator } = this.props.form;
return (
&lt;div className={'my-form'}&gt;
&lt;Form layout="inline"&gt;
&lt;Row&gt;
&lt;Col span={4}&gt;&lt;FormItem {...this.getFormItemLayout()} label={'这是输入框label:'}&gt; {getFieldDecorator('name', {})( //这里的name即表单输入框的name属性值 &lt;Input /&gt; )}&lt;/FormItem&gt;
&lt;/Col&gt;
&lt;/Row&gt;
&lt;/Form&gt;
&lt;/div&gt;
);
}
} //注意,必须有这一步才能在组件中通过this.props.form获取getFieldDecorator。
const WrappedForm = Form.create()(MyForm );

上面的代码我们用getFieldDecorator处理了表单,接下来就可以通过一些官方提供的api获取输入框的值了。如果需要给表单提供验证或默认值,则在使用getFieldDecorator是传入指定的参数即可。

代码如下:


{getFieldDecorator('name', {
initialValue: 'defaultValue', //默认值
rules: [ { // 验证规则
required: true, message: '请输入内容',
}]
})(
&lt;Input /&gt;
)}

我们在获取表单的值的时候,如果需要验证表单,则可以通过下面的代码触发表单并获取到值:


this.props.form.validateFieldsAndScroll((err, values) =&gt; {
if (!err) {
console.log('这是表单的值:', values);
}
});

上面代码中,validateFieldsAndScroll作用是校验完后,如果校验不通过的菜单域不在可见范围内,则自动滚动进可见范围。这里也可以使用validateFields, 都可以校验并获取值,但后者不会自动滚动到可见范围。

如果只需要触发校验不需要取值,则直接调用this.props.form.validateFields()就行了。

如果不需要验证表单,则直接调用getFieldsValue获取值即可。


const form = this.props.form;
const values = form.getFieldsValue();

如果我们已经将表单作为公用子组件分离出去了,那么在父组件中我们又需要能获取到子组件的表单的值,这时我们可以在子组件中定义一个方法专门获取表单的值,然后在父组件中使用属性wrappedComponentRef使我们能够随时调用子组件的表单取值方法。

子组件中:


getValues = () =&gt; {
const form = this.props.form;
const values = form.getFieldsValue();
return values ;
}

父组件中:

1)先使用wrappedComponentRef获取到子组件表单:


&lt;MyForm wrappedComponentRef={(form) =&gt; this.myForm = form}&gt;&lt;/MyForm &gt;

2)然后调用子组件的取值方法:


//这里的myForm就是上面 1)中wrappedComponentRef里面的myForm,属于自定义名称
const values = this.myForm .getValues();

更多的表单验证规则和校验相关api请参考:https://ant.design/components/form-cn/

3. DatePicker取值赋值

我们都知道,在与后台交互的时候我们获取的时间很可能是YYYY-MM-DD格式的字符串,但在antd中,它的日期组件的值类型确实moment的,这时如果直接给datepicker赋默认值是会报错的。

所以,在赋值之前,我们需要使用moment。

代码如下:

1)先引入moment


import moment from 'moment';

2)为datepicker赋值


{getFieldDecorator('name', {
initialValue: moment('2018-12-19'),
rules: [ { // 验证规则
required: true, message: '请选择时间',
}]
})(
&lt;DatePicker style={{width: '100%'}} format={dateFormat} /&gt;
)}

如果是RangePicker的话,再赋值默认值的时候,可以传入时间数组


{getFieldDecorator('rangedate', {
initialValue: [moment(), moment()] //默认当天
})(
&lt;RangePicker
format={dateFormat}
/&gt;
)}

同理,在datepicker取值的时候,我们获取到的也是moment时间,如果需要转成YYYY-MM-DD格式的时间提交给后台,则需要使用moment中的api了。


import moment from 'moment';
const dateFormat = 'YYYY-MM-DD';
// momentDate为获取到的moment时间值
const formatDate = moment(momentDate).format(dateFormat)

来源:https://blog.csdn.net/qq_33036599/article/details/85090647

react项目中antd组件库的使用需要注意的问题的更多相关文章

  1. 基于 React 封装的高德地图组件,帮助你轻松的接入地图到 React 项目中。

    react-amap 这是一个基于 React 封装的高德地图组件,帮助你轻松的接入地图到 React 项目中. 文档实例预览: Github Web | Gitee Web 特性 ️ 自动加载高德地 ...

  2. react项目中使用less并修改antd主题样式

    一.react项目中使用less 1. 安装配置 npm i -D less less-loader 2. 查看webpack配置 npm run eject 此操作不可逆,生成新的目录. 3. 修改 ...

  3. Antd组件库,利用Menu组件模拟一个简单Tree组件

    当前工作中,前端的主要技术栈用是vue. 那React怎么办呢?总不至于把他扔在墙角吧! 只能在一些很小的项目上,也只有自己一个前端的时候,悄悄的上React. 当然,React项目UI组件还是最喜欢 ...

  4. react项目使用antd

    在开始实践之前要确保搭建React单页面开发环境,如果还没有搭建好开发环境的朋友请移步到如何搭建React单页面开发环境. 首先在命令行模式下创建一个React项目(项目名使用小写字母命名):(win ...

  5. 如何在非 React 项目中使用 Redux

    本文作者:胡子大哈 原文链接:https://scriptoj.com/topic/178/如何在非-react-项目中使用-redux 转载请注明出处,保留原文链接和作者信息. 目录 1.前言 2. ...

  6. 了解CSS in JS(JSS)以及在React项目中配置并使用JSS

    目录 认识JSS 什么是JSS JSS 的常见实现 JSS 的好处与坏处 好处 坏处 使用模块化CSS实现JSS 安装插件 在React项目中的tsconfig.json中添加配置 vscode项目中 ...

  7. 如何优雅地在React项目中使用Redux

    前言 或许你当前的项目还没有到应用Redux的程度,但提前了解一下也没有坏处,本文不会安利大家使用Redux 概念 首先我们会用到哪些框架和工具呢? React UI框架 Redux 状态管理工具,与 ...

  8. react项目中实现元素的拖动和缩放实例

    在react项目中实现此功能可借助 react-rnd 库,文档地址:https://github.com/bokuweb/react-rnd#Screenshot .下面是实例运用: import ...

  9. React项目中实现右键自定义菜单

    最近在react项目中需要实现一个,右键自定义菜单功能.找了找发现纯react项目里没有什么工具可以实现这样的功能,所以在网上搜了搜相关资料.下面我会附上完整的组件代码. (注:以下代码非本人原创,具 ...

随机推荐

  1. Dalvik opcodes 查询smali语法大全

    原文链接:http://pallergabor.uw.hu/androidblog/dalvik_opcodes.html Vx values in the table denote a Dalvik ...

  2. 【ExtAspNet学习笔记】ExtAspNet控件库中常见问题

    1.在Grid控件中添加CheckBoxField控件,选择一行时,如何获取选择的CheckBoxField所对应记录的唯一标识值? ●解决方案: 在前台Grid控件中, 添加“<ext:Che ...

  3. Android新浪微博client(一)——主框架搭建

    原文出自:方杰| http://fangjie.sinaapp.com/?p=62 转载请注明出处 该项目代码已经放到github:https://github.com/JayFang1993/Sin ...

  4. kill 命令

    Linux中的kill命令用来终止指定的进程(terminate a process)的运行,是Linux下进程管理的常用命令.通常,终止一个前台进程可以使用Ctrl+C键,但是,对于一个后台进程就须 ...

  5. kafka官方Quick Start

    1.下载kafka,并上传到服务器 2.如果之前没安装zookeeper,这里可以启动一个简单的zookeeper bin/zookeeper-server-start.sh config/zooke ...

  6. 修改Liunx服务器SSH端口

    为提高Linux系统安全性,我们经常会修改ssh端口,下面以CentOS 6为例: vi /etc/ssh/sshd_config 修改ssh端口,默认配置如下: 修改为自己想要的端口号(小于6553 ...

  7. nignx部署django

    操作系统:Linux wiki 2.6.32-131.0.15.el6.x86_64 nginx版本: nginx-1.5.7 uwsgi版本:uwsgi-2.0.8 大致流程参考:http://ww ...

  8. android 各版本的区别

    三.Android 6.x 新增运行时权限概念 Android6.0或以上版本,用户可以完全控制应用权限.当用户安装一个app时,系统默认给app授权部分基础权限,其他敏感权限,需要开发者自己注意,当 ...

  9. Collecting Bugs (概率dp)

    Ivan is fond of collecting. Unlike other people who collect post stamps, coins or other material stu ...

  10. 星球大战starwar(并查集)

    1015: [JSOI2008]星球大战starwar Time Limit: 3 Sec  Memory Limit: 162 MBSubmit: 5253  Solved: 2395[Submit ...