2019-07-03 20:14:39 +08:00
---
order: 19
title:
zh-CN: 自行处理表单数据
en-US: Handle Form Data Manually
---
## zh-CN
`Form` 具有自动收集数据并校验的功能,但如果您不需要这个功能,或者默认的行为无法满足业务需求,可以选择自行处理数据。
## en-US
`Form` will collect and validate form data automatically. But if you don't need this feature or the default behavior cannot satisfy your business, you can handle form data manually.
```tsx
import { Form, InputNumber } from 'antd';
2022-05-23 14:37:16 +08:00
import React, { useState } from 'react';
2019-07-03 20:14:39 +08:00
2020-12-17 15:09:18 +08:00
type ValidateStatus = Parameters< typeof Form . Item > [0]['validateStatus'];
2022-05-19 09:46:26 +08:00
const validatePrimeNumber = (
number: number,
): {
2022-02-14 17:09:35 +08:00
validateStatus: ValidateStatus;
errorMsg: string | null;
2022-05-19 09:46:26 +08:00
} => {
2019-07-03 20:14:39 +08:00
if (number === 11) {
return {
validateStatus: 'success',
errorMsg: null,
};
}
return {
validateStatus: 'error',
errorMsg: 'The prime between 8 and 12 is 11!',
};
2022-05-19 09:46:26 +08:00
};
2019-07-03 20:14:39 +08:00
const formItemLayout = {
labelCol: { span: 7 },
wrapperCol: { span: 12 },
};
2022-05-19 09:46:26 +08:00
const App: React.FC = () => {
2020-12-17 15:09:18 +08:00
const [number, setNumber] = useState< {
value: number;
validateStatus?: ValidateStatus;
errorMsg?: string | null;
}>({
2019-07-03 20:14:39 +08:00
value: 11,
});
const tips =
'A prime is a natural number greater than 1 that has no positive divisors other than 1 and itself.';
2020-12-17 15:09:18 +08:00
const onNumberChange = (value: number) => {
2019-07-03 20:14:39 +08:00
setNumber({
...validatePrimeNumber(value),
value,
});
};
return (
< Form >
< Form.Item
{...formItemLayout}
label="Prime between 8 & 12"
validateStatus={number.validateStatus}
help={number.errorMsg || tips}
>
< InputNumber min = {8} max = {12} value = {number.value} onChange = {onNumberChange} / >
< / Form.Item >
< / Form >
);
};
2022-05-19 09:46:26 +08:00
export default App;
2019-07-03 20:14:39 +08:00
```