目录
▸
入门
简介
安装
1.x升级指南
版本升级
快速开始
开发前必读
主题与颜色
静态资源
视图与自定义页面
多应用(多后台)
JS组件
常见问题
Laravel Octane
▸
数据表格
基本使用
列的使用和扩展
列的显示和扩展
行的使用和扩展
工具栏
树状表格
组合表头
数据来源以及查询条件
关联关系
查询过滤
列过滤器
快捷搜索
规格筛选器
数据导出
快捷创建
行内编辑
事件
字段翻译
数据软删除
头部和脚部
表格异步渲染
▸
数据表单
基本使用
图片/文件上传
字段的使用
字段扩展
数据源
表单弹窗
关联关系
JSON表单
分步表单
表单验证
工具表单
事件以及表单响应
初始化
表单布局
字段翻译
字段动态显示
▸
数据详情
基本使用
字段显示
关联关系
字段显示扩展
初始化
字段翻译
▸
模型树
基本使用
▸
数据仓库
基本使用
▸
动作
基本使用
数据表格
数据表单
数据详情
模型树
▸
多语言
基本使用
▸
开发扩展
扩展基本使用
开发扩展
▸
页面组件
异步加载
图表
数据统计卡片
模态窗(Modal)
工具表单
下拉菜单
单/复选框
选项卡
警告框
提示窗
Markdown
卡片
▸
区块
区块基本使用
▸
动作以及表单响应
动作以及表单响应
▸
权限控制
权限控制
▸
菜单
菜单基本使用
▸
帮助函数
帮助函数
▸
开发工具
基本使用
▸
自定义登陆认证
自定义登录
▸
自定义头部导航
自定义头部导航条
▸
更新日志
BETA版本更新日志
更新日志
内容导航
1.x
2.x
表单布局
创建时间:2024-06-26 14:10:33 / 更新时间:2024-06-26 14:10:33
# 表单布局 ### 多列布局 (column) ![](http://docs.oneself.icu:10010/storage/markdown/images/bde2b75cecf514acb76eb9872c781f47667bb0a176bb3.png) 类似于上图的左右两列布局方式,可以参考下面的代码来实现 ```php // 第一列占据1/2的页面宽度 $form->column(6, function (Form $form) { $form->text('name')->required(); $form->date('born')->required(); $form->select('education')->options([...])->required(); $form->text('nation')->required(); $form->text('native')->required(); $form->text('job')->required(); $form->text('code')->required(); $form->text('phone')->required(); $form->text('work')->required(); $form->text('census')->required(); }); // 第二列占据1/2的页面宽度 $form->column(6, function (Form $form) { $form->image('avatar'); $form->decimal('wages'); $form->decimal('fund'); $form->decimal('pension'); $form->decimal('fee'); $form->decimal('business'); $form->decimal('other'); $form->text('area')->default(0); $form->textarea('illness'); $form->textarea('comment'); }); // 调整所有表单的宽度 $form->width(9, 2); ``` 以上布局功能使用了`bootstrap`的栅格布局系统,所有列的宽度总和不得超出`12`,并且也支持在`hasMany`和`array`表单中使用 ```php $form->hasMany('jobs', function ($form) { $form->column(6, function (Form $form) { $form->text('name')->required(); $form->date('born')->required(); }); $form->column(6, function (Form $form) { $form->image('avatar'); $form->decimal('wages'); }); }); ``` ### 多行布局 (row) 使用 ```php $form->row(function (Form\Row $form) { $form->width(4)->text('username')->required(); $form->width(3)->text('title'); ... }); $form->row(function (Form\Row $form) { ... }); ... ``` 效果 ![](http://docs.oneself.icu:10010/storage/markdown/images/45f481b11265e6abba75cd4ebd02e454667bb0ae81e2b.png) 并且也支持在`hasMany`和`array`表单中使用 ```php $form->hasMany('jobs', function ($form) { $form->row(function (Form\Row $form) { ... }); $form->row(function (Form\Row $form) { ... }); }); ``` 设置布局为 `horizontal` ```php $form->row(function (Form\Row $form) { $form->horizontal(); ... }); ``` <a name="tab"></a> ### 选项卡表单 (tab) 如果表单元素太多,会导致表单页面太长, 这种情况下可以使用`tab`方法来分隔表单: ```php $form->tab('Basic info', function (Form $form) { $form->text('username'); $form->email('email'); })->tab('Profile', function (Form $form) { $form->image('avatar'); $form->text('address'); $form->mobile('phone'); })->tab('Jobs', function (Form $form) { $form->hasMany('jobs', function ($form) { $form->text('company'); $form->date('start_date'); $form->date('end_date'); }); }) ``` 同时,`tab` 布局中也允许嵌套使用`column`和`row`布局 ```php $form->tab('Basic info', function (Form $form) { $form->column(6, function (Form\BlockForm $form) { $form->display('id'); $form->text('name'); }); $form->column(6, function (Form\BlockForm $form) { $form->text('username'); }); }) ``` 设置默认显示的 `Tab` ```php // 默认显示标题为 标题2 的 Tab $form->getTab()->active('标题2'); // 也可以指定偏移量 $form->getTab()->activeByIndex(1); $form->tab('标题1', function ($form) { ... }); $form->tab('标题2', function ($form) { ... }); ``` #### Fieldset布局 ```php $form->fieldset('分组', function (Form $form) { $form->text('company'); $form->date('start_date'); $form->date('end_date'); }); ``` 如果想要默认收起 ```php $form->fieldset('分组', function (Form $form) { ... })->collapsed(); ``` 效果 ![](http://docs.oneself.icu:10010/storage/markdown/images/99936be36b612d5e066f568e6e6f0b97667bb0bec49a4.png) ### 分块布局 (block) 如果你的表单中字段非常多,那么可以通过以下方式让你的表单分块布局,并且允许嵌套使用`column`和`row`布局 ```php $form->block(8, function (Form\BlockForm $form) { // 设置标题 $form->title('基本设置'); // 显示底部提交按钮 $form->showFooter(); // 设置字段宽度 $form->width(9, 2); $form->column(6, function (Form\BlockForm $form) { $form->display('id'); $form->text('name'); $form->email('email'); $form->image('avatar'); $form->password('password'); }); $form->column(6, function (Form\BlockForm $form) { $form->text('username'); $form->email('mobile'); $form->textarea('description'); }); }); $form->block(4, function (Form\BlockForm $form) { $form->title('分块2'); $form->text('nickname'); $form->number('age'); $form->radio('status')->options(['1' => '默认', 2 => '冻结'])->default(1); $form->next(function (Form\BlockForm $form) { $form->title('分块3'); $form->date('birthday'); $form->date('created_at'); }); }); ``` 效果 ![](http://docs.oneself.icu:10010/storage/markdown/images/b37ee00afe3585f6f103ac75e833fd63667bb0ca0f556.jpg)
上一文章
下一文章
返回顶部
返回主页
返回文档展示页