在 Ant Design Pro Components 中实现 BetaSchemaForm 分组两列布局
2025-06-13 17:42:56作者:凌朦慧Richard
背景介绍
Ant Design Pro Components 是一个基于 Ant Design 的企业级组件库,其中 BetaSchemaForm 组件提供了一种基于 JSON Schema 的声明式表单构建方式。在实际业务场景中,我们经常需要实现复杂的表单布局,比如将表单内容分成左右两列显示。
需求分析
在表单设计中,有时我们需要将一个分组下的内容分成左右两部分显示,每部分包含各自的字段集合。这种布局方式在需要对比显示或节省空间时非常有用。例如:
- 左侧显示基本信息,右侧显示扩展信息
- 左侧为必填项,右侧为选填项
- 左侧为当前状态,右侧为修改选项
解决方案
基本实现方法
通过 BetaSchemaForm 的 valueType: 'group' 和 colProps 属性,我们可以轻松实现两列布局:
const columns = [
{
valueType: 'group',
columns: [
{
title: '左侧分组',
valueType: 'group',
colProps: { span: 12 },
columns: [
{ title: '字段1', dataIndex: 'field1' },
{ title: '字段2', dataIndex: 'field2' }
]
},
{
title: '右侧分组',
valueType: 'group',
colProps: { span: 12 },
columns: [
{ title: '字段3', dataIndex: 'field3' },
{ title: '字段4', dataIndex: 'field4' }
]
}
]
}
];
关键属性说明
- valueType: 'group':声明这是一个分组容器
- colProps: { span: 12 }:设置分组占据的栅格列数,12 表示占据一半宽度
- columns:嵌套的子字段配置
完整示例
下面是一个完整的实现示例,包含了表单的渲染和布局控制:
import { BetaSchemaForm } from '@ant-design/pro-components';
import { Card } from 'antd';
const TwoColumnForm = () => {
const columns = [
{
valueType: 'group',
columns: [
{
title: '基本信息',
valueType: 'group',
colProps: { span: 12 },
columns: [
{ title: '姓名', dataIndex: 'name' },
{ title: '年龄', dataIndex: 'age', valueType: 'digit' }
]
},
{
title: '扩展信息',
valueType: 'group',
colProps: { span: 12 },
columns: [
{ title: '邮箱', dataIndex: 'email', valueType: 'email' },
{ title: '手机号', dataIndex: 'phone', valueType: 'text' }
]
}
]
}
];
return (
<Card style={{ width: 800 }}>
<BetaSchemaForm
grid={true}
columns={columns}
onFinish={async (values) => {
console.log(values);
return true;
}}
/>
</Card>
);
};
布局原理
- 栅格系统:Ant Design 使用 24 栅格系统,
span: 12表示占据一半宽度 - 嵌套结构:外层 group 包含两个内层 group,每个内层 group 设置不同的 span
- grid 属性:
grid={true}启用栅格布局模式,使 colProps 生效
高级用法
响应式布局
可以通过 colProps 设置不同屏幕尺寸下的布局:
colProps: {
xs: 24, // 超小屏幕下占满
sm: 12, // 小屏幕下一半
md: 12, // 中等屏幕下一半
lg: 8 // 大屏幕下三分之一
}
混合布局
可以在分组中混合使用不同比例的列:
columns: [
{
title: '主内容',
valueType: 'group',
colProps: { span: 16 },
// ...
},
{
title: '侧边栏',
valueType: 'group',
colProps: { span: 8 },
// ...
}
]
常见问题
- 布局错乱:确保外层容器宽度足够,避免挤压内部布局
- 字段对齐:同一分组内的字段高度最好保持一致
- 表单验证:分组布局不影响表单验证逻辑,验证规则按字段配置
总结
通过 BetaSchemaForm 的分组和栅格系统,我们可以灵活地实现各种复杂的表单布局。两列布局是其中常见的需求,掌握这种布局方式可以显著提升表单的可读性和用户体验。在实际项目中,可以根据业务需求调整列宽比例和响应式设置,打造最适合当前场景的表单界面。
登录后查看全文
热门项目推荐
相关项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0153- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112
热门内容推荐
最新内容推荐
项目优选
收起
暂无描述
Dockerfile
733
4.75 K
deepin linux kernel
C
31
16
Ascend Extension for PyTorch
Python
651
797
Claude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed.
Get Started
Rust
1.25 K
153
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
1.1 K
611
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.01 K
1.01 K
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
147
237
昇腾LLM分布式训练框架
Python
168
200
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
434
395
暂无简介
Dart
986
253