87 lines
2.5 KiB
Vue
87 lines
2.5 KiB
Vue
|
<docs>
|
|||
|
---
|
|||
|
order: 5
|
|||
|
title:
|
|||
|
zh-CN: 嵌套结构与校验信息
|
|||
|
en-US: Nest
|
|||
|
---
|
|||
|
|
|||
|
## zh-CN
|
|||
|
|
|||
|
`name` 属性支持嵌套数据结构。通过 `validateMessages` 或 `message` 自定义校验信息模板,模板内容可参考[此处](https://github.com/vueComponent/ant-design-vue/blob/next/components/form/utils/messages.ts)。
|
|||
|
|
|||
|
## en-US
|
|||
|
|
|||
|
`name` prop support nest data structure. Customize validate message template with `validateMessages` or `message`. Ref [here](https://github.com/vueComponent/ant-design-vue/blob/next/components/form/utils/messages.ts) about message template.
|
|||
|
</docs>
|
|||
|
<template>
|
|||
|
<a-form
|
|||
|
:model="formState"
|
|||
|
v-bind="layout"
|
|||
|
name="nest-messages"
|
|||
|
:validate-messages="validateMessages"
|
|||
|
@finish="onFinish"
|
|||
|
>
|
|||
|
<a-form-item :name="['user', 'name']" label="Name" :rules="[{ required: true }]">
|
|||
|
<a-input v-model:value="formState.user.name" />
|
|||
|
</a-form-item>
|
|||
|
<a-form-item :name="['user', 'email']" label="Email" :rules="[{ type: 'email' }]">
|
|||
|
<a-input v-model:value="formState.user.email" />
|
|||
|
</a-form-item>
|
|||
|
<a-form-item :name="['user', 'age']" label="Age" :rules="[{ type: 'number', min: 0, max: 99 }]">
|
|||
|
<a-input-number v-model:value="formState.user.age" />
|
|||
|
</a-form-item>
|
|||
|
<a-form-item :name="['user', 'website']" label="Website">
|
|||
|
<a-input v-model:value="formState.user.website" />
|
|||
|
</a-form-item>
|
|||
|
<a-form-item :name="['user', 'introduction']" label="Introduction">
|
|||
|
<a-textarea v-model:value="formState.user.introduction" />
|
|||
|
</a-form-item>
|
|||
|
<a-form-item :wrapper-col="{ ...layout.wrapperCol, offset: 8 }">
|
|||
|
<a-button type="primary" html-type="submit">Submit</a-button>
|
|||
|
</a-form-item>
|
|||
|
</a-form>
|
|||
|
</template>
|
|||
|
<script lang="ts">
|
|||
|
import { defineComponent, reactive } from 'vue';
|
|||
|
|
|||
|
export default defineComponent({
|
|||
|
setup() {
|
|||
|
const layout = {
|
|||
|
labelCol: { span: 8 },
|
|||
|
wrapperCol: { span: 16 },
|
|||
|
};
|
|||
|
|
|||
|
const validateMessages = {
|
|||
|
required: '${label} is required!',
|
|||
|
types: {
|
|||
|
email: '${label} is not a valid email!',
|
|||
|
number: '${label} is not a valid number!',
|
|||
|
},
|
|||
|
number: {
|
|||
|
range: '${label} must be between ${min} and ${max}',
|
|||
|
},
|
|||
|
};
|
|||
|
|
|||
|
const formState = reactive({
|
|||
|
user: {
|
|||
|
name: '',
|
|||
|
age: undefined,
|
|||
|
email: '',
|
|||
|
website: '',
|
|||
|
introduction: '',
|
|||
|
},
|
|||
|
});
|
|||
|
const onFinish = (values: any) => {
|
|||
|
console.log('Success:', values);
|
|||
|
};
|
|||
|
return {
|
|||
|
formState,
|
|||
|
onFinish,
|
|||
|
layout,
|
|||
|
validateMessages,
|
|||
|
};
|
|||
|
},
|
|||
|
});
|
|||
|
</script>
|