11 KiB
		
	
	
	
	
			
		
		
	
	API
Form
| Property | Description | Type | Default Value | 
|---|---|---|---|
| form | Decorated by Form.create()will be automatically setthis.formproperty, so just pass to form. If you use the template syntax, you can usethis.$form.createForm(this, options) | object | n/a | 
| hideRequiredMark | Hide required mark of all form items | Boolean | false | 
| layout | Define form layout | 'horizontal'|'vertical'|'inline' | 'horizontal' | 
| autoFormCreate(deprecated) | Automate Form.create, Recommended for use under the templatecomponent, and cannot be used withForm.create(). You should use$form.createFormto instead it after 1.1.9. | Function(form) | |
| options(deprecated) | The optionscorresponding toForm.create(options).  You should use$form.createFormto instead it after 1.1.9. | Object | {} | 
Events
| Events Name | Description | Arguments | 
|---|---|---|
| submit | Defines a function will be called if form data validation is successful. | Function(e:Event) | 
Form.create(options) | this.$form.createForm(this, options)
How to use:
Used in jsx, the usage is consistent with the React version of antd
const CustomizedForm = {}
CustomizedForm = Form.create({})(CustomizedForm);
Maintain an ref for wrapped component instance, use wrappedComponentRef.
Single file template usage
<template>
<a-form :form="form" />
</template>
<script>
export default {
  beforeCreate () {
    this.form = this.$form.createForm(this, options)
  },
}
</script>
The following options are available:
| Property | Description | Type | 
|---|---|---|
| props | Only supports the use of Form.create({})(CustomizedForm). declare props on form(和like vue props) | {} | 
| mapPropsToFields | Convert props to field value(e.g. reading the values from Redux store). And you must mark returned fields with Form.createFormField. If you use$form.createFormto create a collector, you can map any data to the Field without being bound by the parent component. | (props) => Object{ fieldName: FormField { value } } | 
| validateMessages | Default validate message. And its format is similar with newMessages's returned value | Object { [nested.path]: String } | 
| onFieldsChange | Specify a function that will be called when the value a Form.Itemgets changed. Usage example: saving the field's value to Redux store. | Function(props, fields) | 
| onValuesChange | A handler while value of any field is changed | (props, values) => void | 
If the form has been decorated by Form.create then it has this.form property. this.form provides some APIs as follows:
Note: Before using
getFieldsValuegetFieldValuesetFieldsValueand so on, please make sure that corresponding field had been registered withgetFieldDecorator.
| Method | Description | Type | 
|---|---|---|
| getFieldDecorator | Two-way binding for form, single file template can be bound using the directive v-decorator. please read below for details. | |
| getFieldError | Get the error of a field. | Function(name) | 
| getFieldsError | Get the specified fields' error. If you don't specify a parameter, you will get all fields' error. | Function([names: string[]]) | 
| getFieldsValue | Get the specified fields' values. If you don't specify a parameter, you will get all fields' values. | Function([fieldNames: string[]]) | 
| getFieldValue | Get the value of a field. | Function(fieldName: string) | 
| isFieldsTouched | Check whether any of fields is touched by getFieldDecorator'soptions.triggerevent | (names?: string[]) => boolean | 
| isFieldTouched | Check whether a field is touched by getFieldDecorator'soptions.triggerevent | (name: string) => boolean | 
| isFieldValidating | Check if the specified field is being validated. | Function(name) | 
| resetFields | Reset the specified fields' value(to initialValue) and status. If you don't specify a parameter, all the fields will be reset. | Function([names: string[]]) | 
| setFields | Set value and error state of fields. | ({ [fieldName]: {value: any, errors: [Error] } }) => void | 
| setFieldsValue | Set the value of a field. | Function({ [fieldName]: value } | 
| validateFields | Validate the specified fields and get theirs values and errors. If you don't specify the parameter of fieldNames, you will validate all fields. | ( [fieldNames: string[]], [options: object], callback(errors, values) ) => void | 
| validateFieldsAndScroll | This function is similar to validateFields, but after validation, if the target field is not in visible area of form, form will be automatically scrolled to the target field area. | same as validateFields | 
validateFields/validateFieldsAndScroll
const { form: { validateFields } } = this;
validateFields((errors, values) => {
  // ...
});
validateFields(['field1', 'field2'], (errors, values) => {
  // ...
});
validateFields(['field1', 'field2'], options, (errors, values) => {
  // ...
});
| Method | Description | Type | Default | 
|---|---|---|---|
| options.first | If true, every field will stop validation at first failed rule | boolean | false | 
| options.firstFields | Those fields will stop validation at first failed rule | String[] | [] | 
| options.force | Should validate validated field again when validateTriggeris been triggered again | boolean | false | 
| options.scroll | Config scroll behavior of validateFieldsAndScroll, more: dom-scroll-into-view's config | Object | {} | 
Callback arguments example of validateFields
- 
errors:{ "userName": { "errors": [ { "message": "Please input your username!", "field": "userName" } ] }, "password": { "errors": [ { "message": "Please input your Password!", "field": "password" } ] } }
- 
values:{ "userName": "username", "password": "password", }
Form.createFormField
To mark the returned fields data in mapPropsToFields, demo.
this.form.getFieldDecorator(id, options) and v-decorator="[id, options]"
After wrapped by getFieldDecorator or v-decorator, value(or other property defined by valuePropName) onChange(or other property defined by trigger) props will be added to form controls,the flow of form data will be handled by Form which will cause:
- You shouldn't use onChangeto collect data, but you still can listen toonChange(and so on) events.
- You cannot set value of form control via valuedefaultValueprop, and you should set default value withinitialValueingetFieldDecoratorinstead.
- You shouldn't call v-modelmanually, please usethis.form.setFieldsValueto change value programmatically.
Special attention
- getFieldDecoratorand- v-decoratorcan not be used to decorate stateless component.
- you can't use getFieldDecoratorandv-decoratorin stateless component: https://vuejs.org/v2/api/#functional
getFieldDecorator(id, options) and v-decorator="[id, options]" parameters
| Property | Description | Type | Default Value | 
|---|---|---|---|
| id | The unique identifier is required. support nested fields format. | string | |
| options.getValueFromEvent | Specify how to get value from event or other onChange arguments | function(..args) | reference | 
| options.getValueProps | Get the component props according to field value. | function(value): any | reference | 
| options.initialValue | You can specify initial value, type, optional value of children node. (Note: Because Formwill test equality with===internally, we recommend to use variable asinitialValue, instead of literal) | n/a | |
| options.normalize | Normalize value to form component, a select-all example | function(value, prevValue, allValues): any | - | 
| options.rules | Includes validation rules. Please refer to "Validation Rules" part for details. | object[] | n/a | 
| options.trigger | When to collect the value of children node | string | 'change' | 
| options.validateFirst | Whether stop validate on first rule of error for this field. | boolean | false | 
| options.validateTrigger | When to validate the value of children node. | string|string[] | 'change' | 
| options.valuePropName | Props of children node, for example, the prop of Switch is 'checked'. | string | 'value' | 
Form.Item
Note: If Form.Item has multiple children that had been decorated by getFieldDecorator or v-decorator, help and required and validateStatus can't be generated automatically.
| Property | Description | Type | Default Value | 
|---|---|---|---|
| colon | Used with label, whether to display:after label text. | boolean | true | 
| extra | The extra prompt message. It is similar to help. Usage example: to display error message and prompt message at the same time. | string|slot | |
| hasFeedback | Used with validateStatus, this option specifies the validation status icon. Recommended to be used only withInput. | boolean | false | 
| help | The prompt message. If not provided, the prompt message will be generated by the validation rule. | string|slot | |
| label | Label text | string|slot | |
| labelCol | The layout of label. You can set spanoffsetto something like{span: 3, offset: 12}orsm: {span: 3, offset: 12}same as with<Col> | object | |
| required | Whether provided or not, it will be generated by the validation rule. | boolean | false | 
| validateStatus | The validation status. If not provided, it will be generated by validation rule. options: 'success' 'warning' 'error' 'validating' | string | |
| wrapperCol | The layout for input controls, same as labelCol | object | 
Validation Rules
| Property | Description | Type | Default Value | 
|---|---|---|---|
| enum | validate a value from a list of possible values | string | - | 
| len | validate an exact length of a field | number | - | 
| max | validate a max length of a field | number | - | 
| message | validation error message | string | - | 
| min | validate a min length of a field | number | - | 
| pattern | validate from a regular expression | RegExp | - | 
| required | indicates whether field is required | boolean | false | 
| transform | transform a value before validation | function(value) => transformedValue:any | - | 
| type | built-in validation type, available options | string | 'string' | 
| validator | custom validate function (Note: callback must be called) | function(rule, value, callback) | - | 
| whitespace | treat required fields that only contain whitespace as errors | boolean | false | 
See more advanced usage at async-validator.