ant-design/components/form/demo/layout.md

73 lines
1.8 KiB
Markdown
Raw Normal View History

---
order: 12
title:
zh-CN: 表单布局
en-US: Form Layout
---
## zh-CN
表单有三种布局。
## en-US
There are three layout for form: `horizontal`, `vertical`, `inline`.
2019-05-07 14:57:32 +08:00
```jsx
import { Form, Input, Button, Radio } from 'antd';
2018-06-27 15:55:04 +08:00
class FormLayoutDemo extends React.Component {
constructor() {
super();
this.state = {
formLayout: 'horizontal',
};
}
2018-06-27 15:55:04 +08:00
2019-05-07 14:57:32 +08:00
handleFormLayoutChange = e => {
this.setState({ formLayout: e.target.value });
2019-05-07 14:57:32 +08:00
};
2018-06-27 15:55:04 +08:00
render() {
const { formLayout } = this.state;
2019-05-07 14:57:32 +08:00
const formItemLayout =
formLayout === 'horizontal'
? {
labelCol: { span: 4 },
wrapperCol: { span: 14 },
}
: null;
const buttonItemLayout =
formLayout === 'horizontal'
? {
wrapperCol: { span: 14, offset: 4 },
}
: null;
return (
<div>
<Form layout={formLayout}>
2019-05-07 14:57:32 +08:00
<Form.Item label="Form Layout" {...formItemLayout}>
<Radio.Group defaultValue="horizontal" onChange={this.handleFormLayoutChange}>
<Radio.Button value="horizontal">Horizontal</Radio.Button>
<Radio.Button value="vertical">Vertical</Radio.Button>
<Radio.Button value="inline">Inline</Radio.Button>
</Radio.Group>
2018-12-22 16:48:30 +08:00
</Form.Item>
2019-05-07 14:57:32 +08:00
<Form.Item label="Field A" {...formItemLayout}>
<Input placeholder="input placeholder" />
2018-12-22 16:48:30 +08:00
</Form.Item>
2019-05-07 14:57:32 +08:00
<Form.Item label="Field B" {...formItemLayout}>
<Input placeholder="input placeholder" />
2018-12-22 16:48:30 +08:00
</Form.Item>
<Form.Item {...buttonItemLayout}>
2017-07-16 15:41:51 +08:00
<Button type="primary">Submit</Button>
2018-12-22 16:48:30 +08:00
</Form.Item>
</Form>
</div>
);
}
}
ReactDOM.render(<FormLayoutDemo />, mountNode);
2019-05-07 14:57:32 +08:00
```