mirror of
https://github.com/ant-design/ant-design.git
synced 2025-06-29 08:01:26 +08:00

* init form * first demo * add normal login * add style * webit * support nest errors * beauti form errors * use onReset * modal demo * add list demo * match key of errors logic * date demo * customize component * moving style * add status style * without form create * add demos * add inline style * clean up legacy * fix drawer demo * mention * fix edit-row * editable table cell * update mentions demo * fix some test case * fix upload test * fix lint * part of doc * fix ts * doc update * rm react 15 * rm config * enhance test coverage * clean up * fix FormItem context pass logic * add more demo * en to build * update demo * update demo & snapshot * more doc * update list doc * update doc * update demo to display condition render * update snapshot * add provider doc * support configProvider * more doc about validateMessages * more description * more and more doc * fix typo * en doc * Form.List doc * m v3 -> v4 * add skip
126 lines
3.5 KiB
Markdown
126 lines
3.5 KiB
Markdown
---
|
|
order: 20
|
|
title:
|
|
zh-CN: 自定义校验
|
|
en-US: Customized Validation
|
|
---
|
|
|
|
## zh-CN
|
|
|
|
我们提供了 `validateStatus` `help` `hasFeedback` 等属性,你可以不通过 Form 自己定义校验的时机和内容。
|
|
|
|
1. `validateStatus`: 校验状态,可选 'success', 'warning', 'error', 'validating'。
|
|
2. `hasFeedback`:用于给输入框添加反馈图标。
|
|
3. `help`:设置校验文案。
|
|
|
|
## en-US
|
|
|
|
We provide properties like `validateStatus` `help` `hasFeedback` to customize your own validate status and message, without using Form.
|
|
|
|
1. `validateStatus`: validate status of form components which could be 'success', 'warning', 'error', 'validating'.
|
|
2. `hasFeedback`: display feed icon of input control
|
|
3. `help`: display validate message.
|
|
|
|
```tsx
|
|
import { Form, Input, DatePicker, TimePicker, Select, Cascader, InputNumber } from 'antd';
|
|
|
|
const { Option } = Select;
|
|
|
|
const formItemLayout = {
|
|
labelCol: {
|
|
xs: { span: 24 },
|
|
sm: { span: 5 },
|
|
},
|
|
wrapperCol: {
|
|
xs: { span: 24 },
|
|
sm: { span: 12 },
|
|
},
|
|
};
|
|
|
|
ReactDOM.render(
|
|
<Form {...formItemLayout}>
|
|
<Form.Item
|
|
label="Fail"
|
|
validateStatus="error"
|
|
help="Should be combination of numbers & alphabets"
|
|
>
|
|
<Input placeholder="unavailable choice" id="error" />
|
|
</Form.Item>
|
|
|
|
<Form.Item label="Warning" validateStatus="warning">
|
|
<Input placeholder="Warning" id="warning" />
|
|
</Form.Item>
|
|
|
|
<Form.Item
|
|
label="Validating"
|
|
hasFeedback
|
|
validateStatus="validating"
|
|
help="The information is being validated..."
|
|
>
|
|
<Input placeholder="I'm the content is being validated" id="validating" />
|
|
</Form.Item>
|
|
|
|
<Form.Item label="Success" hasFeedback validateStatus="success">
|
|
<Input placeholder="I'm the content" id="success" />
|
|
</Form.Item>
|
|
|
|
<Form.Item label="Warning" hasFeedback validateStatus="warning">
|
|
<Input placeholder="Warning" id="warning2" />
|
|
</Form.Item>
|
|
|
|
<Form.Item
|
|
label="Fail"
|
|
hasFeedback
|
|
validateStatus="error"
|
|
help="Should be combination of numbers & alphabets"
|
|
>
|
|
<Input placeholder="unavailable choice" id="error2" />
|
|
</Form.Item>
|
|
|
|
<Form.Item label="Success" hasFeedback validateStatus="success">
|
|
<DatePicker style={{ width: '100%' }} />
|
|
</Form.Item>
|
|
|
|
<Form.Item label="Warning" hasFeedback validateStatus="warning">
|
|
<TimePicker style={{ width: '100%' }} />
|
|
</Form.Item>
|
|
|
|
<Form.Item label="Error" hasFeedback validateStatus="error">
|
|
<Select defaultValue="1">
|
|
<Option value="1">Option 1</Option>
|
|
<Option value="2">Option 2</Option>
|
|
<Option value="3">Option 3</Option>
|
|
</Select>
|
|
</Form.Item>
|
|
|
|
<Form.Item
|
|
label="Validating"
|
|
hasFeedback
|
|
validateStatus="validating"
|
|
help="The information is being validated..."
|
|
>
|
|
<Cascader defaultValue={['1']} options={[]} />
|
|
</Form.Item>
|
|
|
|
<Form.Item label="inline" style={{ marginBottom: 0 }}>
|
|
<Form.Item
|
|
validateStatus="error"
|
|
help="Please select the correct date"
|
|
style={{ display: 'inline-block', width: 'calc(50% - 12px)' }}
|
|
>
|
|
<DatePicker />
|
|
</Form.Item>
|
|
<span style={{ display: 'inline-block', width: '24px', textAlign: 'center' }}>-</span>
|
|
<Form.Item style={{ display: 'inline-block', width: 'calc(50% - 12px)' }}>
|
|
<DatePicker />
|
|
</Form.Item>
|
|
</Form.Item>
|
|
|
|
<Form.Item label="Success" hasFeedback validateStatus="success">
|
|
<InputNumber style={{ width: '100%' }} />
|
|
</Form.Item>
|
|
</Form>,
|
|
mountNode,
|
|
);
|
|
```
|