8.9 KiB
真实表单设计案例参考
从 JeecgBoot 演示系统
design_form表中提取的真实表单配置,涵盖 OA、HR、行政等常见业务场景。
1. 字典翻译示例 (demo_test_dict_transl)
场景: 展示 radio/checkbox/select 的三种数据源(静态、字典、远程)
控件清单(18个):
- 单行文本 (input)
- 单选框组_远程数据 (radio) —
remote: true, remoteFunc: "http://..." - 单选框组_静态数据 (radio) —
showLabel: true, options: [{value:"1",label:"数学"}, ...] - 单选框组 (radio) —
remote: "dict", dictCode: "sex" - 多选框组 (checkbox) —
remote: "dict", dictCode: "sex" - 多选框组_静态数据 (checkbox) — 静态选项
- 下拉选择框 (select) —
showLabel: true, options: [{value:"1",label:"选项1"}, ...] - 下拉选择框_多选 (select) —
multiple: true - 下拉选择框_字典 (select) —
remote: "dict", dictCode: "urgent_level" - 开关 (switch)
- 省市级联动 (area-linkage)
- 用户组件 (select-user) —
multiple: true - 部门组件 (select-depart) —
multiple: true - 下拉树_分类字典 (select-tree) —
multiple: true - 下拉树_表 (select-tree) —
multiple: true - 表字典_popup (table-dict) —
multiple: true - 表字典_模糊online (table-dict) —
multiple: true - 表字典_模糊表 (table-dict) —
multiple: true
关键配置模式 — 字典 radio:
{
"type": "radio",
"name": "单选框组",
"options": {
"inline": true,
"showLabel": true,
"remote": "dict",
"dictCode": "sex",
"options": [
{"value": "选项1", "itemColor": "#e9e9e9"},
{"value": "选项2", "itemColor": "#e9e9e9"}
],
"remoteOptions": [],
"props": {"value": "value", "label": "label"},
"remoteFunc": "",
"useColor": false,
"showType": "default",
"colorIteratorIndex": 0,
"matrixWidth": 120
},
"advancedSetting": {
"defaultValue": {
"type": "compose", "value": "", "format": "string",
"allowFunc": true, "valueSplit": ",", "customConfig": true
}
}
}
关键配置模式 — 静态 radio (showLabel+value/label):
{
"type": "radio",
"options": {
"showLabel": true,
"remote": false,
"options": [
{"value": "1", "label": "数学", "itemColor": "#e9e9e9"},
{"value": "2", "label": "语文", "itemColor": "#e9e9e9"},
{"value": "3", "label": "自然", "itemColor": "#e9e9e9"}
]
}
}
注意: 当
showLabel: true时,选项需要同时有value(存储值)和label(显示文本)。 当showLabel: false时,value既是存储值也是显示文本。
2. 请假申请 (qing_jia_shen_qing_5qfk)
场景: 典型 OA 审批表单
控件清单(12个):
- 姓名 (select-user) — 必填,
defaultLogin: true - 所在部门 (select-depart)
- 申请日期 (date)
- 请假类型 (select) — 选项:事假/病假/年假/调休
- 开始日期 (date)
- 结束日期 (date)
- 天数 (number)
- 请假说明 (textarea)
- 审批意见 (radio) — 选项:同意/不同意
- 直属领导 (select-user)
- 审批时间 (date)
- 附件 (file-upload)
config:
{
"titleField": "select_user_1692952011928_137220",
"hasWidgets": ["select-user", "select-depart", "date", "card", "select", "number", "textarea", "radio", "file-upload"]
}
要点:
titleField指向 select-user 控件(而非 input),说明 titleField 可以指向任何控件类型。
3. 员工基本信息 (yuan_gong_ji_ben_xin_xi_dnjq)
场景: HR 员工档案,展示半行布局
控件清单(8个,全部半行两两配对):
- [半行] 姓名 (select-user) | 所在部门 (select-depart)
- [半行] 岗位 (input) | 性别 (select) — 选项:男/女
- [半行] 入职时间 (date) | 参加工作时间 (date)
- [半行] 直属上级 (select-user) | 负责 HR (select-user)
config:
{
"titleField": "select_user_1692874017319_686764",
"hasWidgets": ["select-user", "select-depart", "card", "input", "select", "date"]
}
要点: 整个表单全部使用半行布局(每个 card 内 2 个控件,autoWidth: 50)。
4. 用车申请 (yong_che_shen_qing_gh3j)
场景: 行政用车,展示 area-linkage + formula + link-record + divider
控件清单(21个):
- 申请日期 (date) — 必填
- 申请人 (select-user) — 必填
- 申请部门 (select-depart)
- 用车人数 (integer) — 必填
- 要求用车时间 (date)
- 出发地 (area-linkage)
- 出发地详细地址 (input)
- 目的地 (area-linkage)
- 目的地详细地址 (input)
- 随行司机 (select-user)
- 用车理由 (textarea)
- 分隔符 (divider)
- 出发时间 (date)
- 返程时间 (date)
- 车牌号码 (link-record) — 关联记录
- 起始公里数 (number)
- 到达公里数 (number)
- 行驶公里数 (formula) — 公式计算
- 停车费 (money)
- 备注 (textarea)
- 附件 (file-upload)
config:
{
"hasWidgets": ["date", "select-user", "select-depart", "integer", "card", "area-linkage", "input", "textarea", "divider", "link-record", "number", "formula", "money", "file-upload"]
}
要点:
- 使用
divider分隔"申请信息"和"用车记录"两个区域formula控件自动计算行驶公里数link-record关联车辆信息表
5. 工资表 (gong_zi_biao_zitx)
场景: HR 薪资管理,展示 divider 分区 + formula 计算 + money 字段
控件清单(17个):
- 工资发放时间 (date)
- 分隔符 (divider) — 基本信息区
- 姓名 (select-user) — 必填
- 部门 (select-depart)
- 手机号码 (phone)
- 分隔符 (divider) — 收入区
- 基本工资 (money)
- 加班工资 (money)
- 奖金 (money)
- 补贴 (money)
- 分隔符 (divider) — 扣款区
- 本期扣款 (money)
- 五险一金扣款 (money)
- 个税扣除 (money)
- 实发金额 (formula) — 公式自动计算
- 备注 (textarea)
- 附件 (file-upload)
config:
{
"hasWidgets": ["date", "card", "divider", "select-user", "select-depart", "phone", "money", "formula", "textarea", "file-upload"]
}
要点:
- 用多个
divider将表单分为"基本信息"、"收入"、"扣款"三个区域formula控件计算实发金额 = 基本工资+加班+奖金+补贴-扣款-五险一金-个税- 大量使用
money控件(带"元"后缀)
6. 会议预约 (hui_yi_yu_yue_0s2h)
场景: 行政会议管理,展示 link-record + link-field 关联
控件清单(14个):
- 预约人 (select-user) — 必填
- 所属部门 (select-depart) — 必填
- 当前时间 (date) — 必填
- 会议名称 (input) — 必填
- 会议室基础表 (link-record) — 关联记录
- 会议室名称 (link-field) — 他表字段(自动填充)
- 会议室编号 (link-field)
- 会议室容纳人数 (link-field)
- 参会人员 (select-user) —
multiple: true(多选) - 会议开始时间 (date)
- 会议结束时间 (date)
- 预约时间 (input)
- 备注 (textarea)
- 附件 (file-upload)
config:
{
"hasWidgets": ["select-user", "select-depart", "date", "card", "input", "link-record", "link-field", "textarea", "file-upload"]
}
要点:
link-record选择会议室后,link-field自动填充关联数据(名称、编号、容纳人数)select-user支持multiple: true多选参会人员
7. 地图/定位/省市联动综合 (ceshi_ditu)
场景: 展示地图、表字典、下拉树、多选用户/部门
控件清单(9个):
- 用户组件 (select-user) —
multiple: true - 部门组件 (select-depart) —
multiple: true - 表字典_popupOL报表 (table-dict)
- 表字典_模糊OL报表 (table-dict)
- 表字典_模糊表 (table-dict)
- 下拉树_分类字典 (select-tree)
- 下拉树_表 (select-tree)
- 性别 (radio) —
remote: "dict", dictCode: "sex" - 地图 (map) — 不需要 card 容器
要点:
map控件直接放在顶层 list,不需要 card 容器。
常用字典编码速查
从真实表单中收集到的字典编码:
| dictCode | 说明 | 使用场景 |
|---|---|---|
sex |
性别 | radio/checkbox/select |
position_rank |
职级 | select 多选 |
urgent_level |
紧急程度 | select 多选 |
设计模式总结
| 模式 | 说明 | 示例表单 |
|---|---|---|
| 字典数据源 | remote:"dict" + dictCode |
字典翻译示例 |
| 半行布局 | card 内两控件 autoWidth:50 |
员工基本信息 |
| 分区分隔 | divider 控件分割表单区域 | 工资表、用车申请 |
| 公式计算 | formula 控件自动计算 | 工资表、用车申请 |
| 关联填充 | link-record + link-field | 会议预约 |
| 默认当前用户 | select-user defaultLogin:true |
请假申请 |
| 多选人员 | select-user multiple:true |
会议预约、字典示例 |
| titleField 灵活 | 可指向 select-user 等非 input 控件 | 请假申请、员工信息 |