173 lines
5.1 KiB
Vue
173 lines
5.1 KiB
Vue
<docs>
|
||
---
|
||
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.
|
||
</docs>
|
||
<template>
|
||
<a-form v-bind="formItemLayout">
|
||
<a-form-item
|
||
label="Fail"
|
||
validate-status="error"
|
||
help="Should be combination of numbers & alphabets"
|
||
>
|
||
<a-input id="error" placeholder="unavailable choice" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Warning" validate-status="warning">
|
||
<a-input id="warning" placeholder="Warning">
|
||
<template #prefix><smile-outlined /></template>
|
||
</a-input>
|
||
</a-form-item>
|
||
|
||
<a-form-item
|
||
label="Validating"
|
||
has-feedback
|
||
validate-status="validating"
|
||
help="The information is being validated..."
|
||
>
|
||
<a-input id="validating" placeholder="I'm the content is being validated" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Success" has-feedback validate-status="success">
|
||
<a-input id="success" placeholder="I'm the content" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Warning" has-feedback validate-status="warning">
|
||
<a-input id="warning2" placeholder="Warning" />
|
||
</a-form-item>
|
||
|
||
<a-form-item
|
||
label="Fail"
|
||
has-feedback
|
||
validate-status="error"
|
||
help="Should be combination of numbers & alphabets"
|
||
>
|
||
<a-input id="error2" placeholder="unavailable choice" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Success" has-feedback validate-status="success">
|
||
<a-date-picker style="width: 100%" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Warning" has-feedback validate-status="warning">
|
||
<a-time-picker style="width: 100%" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Error" has-feedback validate-status="error">
|
||
<a-range-picker style="width: 100%" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Error" has-feedback validate-status="error">
|
||
<a-select placeholder="I'm Select" allow-clear>
|
||
<a-select-option value="1">Option 1</a-select-option>
|
||
<a-select-option value="2">Option 2</a-select-option>
|
||
<a-select-option value="3">Option 3</a-select-option>
|
||
</a-select>
|
||
</a-form-item>
|
||
|
||
<a-form-item
|
||
label="Validating"
|
||
has-feedback
|
||
validate-status="error"
|
||
help="Something breaks the rule."
|
||
>
|
||
<a-cascader
|
||
placeholder="I'm Cascader"
|
||
:options="[{ value: 'xx', label: 'xx' }]"
|
||
allow-clear
|
||
/>
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Warning" has-feedback validate-status="warning" help="Need to be checked">
|
||
<a-tree-select
|
||
placeholder="I'm TreeSelect"
|
||
:tree-data="[{ value: 'xx', label: 'xx' }]"
|
||
allow-clear
|
||
/>
|
||
</a-form-item>
|
||
|
||
<a-form-item label="inline" style="margin-bottom: 0px">
|
||
<a-form-item
|
||
validate-status="error"
|
||
help="Please select right date"
|
||
style="display: inline-block; width: calc(50% - 12px)"
|
||
>
|
||
<a-date-picker />
|
||
</a-form-item>
|
||
<span style="display: inline-block, width: 24px; line-height:32px; text-align: center">
|
||
-
|
||
</span>
|
||
<a-form-item style="display: inline-block; width: calc(50% - 12px)">
|
||
<a-date-picker />
|
||
</a-form-item>
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Success" has-feedback validate-status="success">
|
||
<a-inputNumber style="width: 100%" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Success" has-feedback validate-status="success">
|
||
<a-input allow-clear placeholder="with allowClear" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Warning" has-feedback validate-status="warning">
|
||
<a-input-password placeholder="with input password" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Error" has-feedback validate-status="error">
|
||
<a-input-password allow-clear placeholder="with input password and allowClear" />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Fail" validate-status="error" has-feedback>
|
||
<a-mentions />
|
||
</a-form-item>
|
||
|
||
<a-form-item label="Fail" validate-status="error" has-feedback help="Should have something">
|
||
<a-textarea allow-clear show-count />
|
||
</a-form-item>
|
||
</a-form>
|
||
</template>
|
||
<script lang="ts">
|
||
import { defineComponent } from 'vue';
|
||
import { SmileOutlined } from '@ant-design/icons-vue';
|
||
export default defineComponent({
|
||
components: {
|
||
SmileOutlined,
|
||
},
|
||
setup() {
|
||
const formItemLayout = {
|
||
labelCol: {
|
||
xs: { span: 24 },
|
||
sm: { span: 6 },
|
||
},
|
||
wrapperCol: {
|
||
xs: { span: 24 },
|
||
sm: { span: 14 },
|
||
},
|
||
};
|
||
return {
|
||
formItemLayout,
|
||
};
|
||
},
|
||
});
|
||
</script>
|