## 列表Builder构建器
### 说明
列表构建器整合Bootstrap-table实现快速构建一个列表页面
### 用法
例:
```
// 获取所有用户
$condition =[
'status'=> ['egt', '0'], // 禁用和正常状态
];
/**
*$condition查询条件支持闭包查询
*/
list($data_list,$total) = model('common/User')
->search('username|nickname')//搜索
->getListByPage($condition,true,'create_time desc',12);
$reset_password = [
'icon'=> 'fa fa-recycle',
'title'=>'重置原始密码',
'class'=>'btn btn-default ajax-table-btn confirm btn-sm',
'confirm-info'=>'该操作会重置用户密码为123456,请谨慎操作',
'href'=>url('resetPassword')
];
return builder('List')
->setMetaTitle('用户管理') // 设置页面标题
->addTopButton('addnew') // 添加新增按钮
->addTopButton('delete') // 添加删除按钮
->addTopButton('self',$reset_password) // 添加重置按钮
->setSearch('custom','请输入关键字')//自定义搜索框
->keyListItem('uid', 'UID')
->keyListItem('avatar', '头像', 'avatar')
->keyListItem('nickname', '昵称')
->keyListItem('username', '用户名')
->keyListItem('email', '邮箱')
->keyListItem('mobile', '手机号')
->keyListItem('reg_time', '注册时间')
->keyListItem('allow_admin', '允许进入后台','status')
->keyListItem('status', '状态', 'array',[0=>'禁用',1=>'正常',2=>'待验证'])
->keyListItem('right_button', '操作', 'btn')
->setListPrimaryKey('uid')//设置主键uid(默认id)
->setExtraHtml($extra_html)//自定义html
->setListData($data_list) // 数据列表
->setListPage($total,12) // 数据列表分页
->addRightButton('edit') //添加编辑按钮
->addRightButton('delete') // 添加编辑按钮
->fetch();
```
### 效果图
![](https://box.kancloud.cn/cc4d68d4fb84720c057333dac4772228_1306x692.jpg)
### 讲解:
从上面的代码示例中体现构建器List的使用要点:
1.模型的数据查询,包含返回数据总量。
~~~
list($data_list,$total) = model('common/User')->search('username|nickname')->getListByPage($map,true,'create_time desc',12);
~~~
2.自定义头部操作按钮。
~~~
$reset_password = [
'icon'=> 'fa fa-recycle',
'title'=>'重置原始密码',
'class'=>'btn btn-default ajax-table-btn confirm btn-sm',
'confirm-info'=>'该操作会重置用户密码为123456,请谨慎操作',
'href'=>url('resetPassword')
];
->addTopButton('self',$reset_password) // 添加重置按钮
~~~
3.添加列表项
~~~
->keyListItem('username', '用户名')
~~~
4.设置列表主键,批量操作会用到
~~~
->setListPrimaryKey('uid') //设置主键uid(默认id)
~~~
5.列表数据赋值
~~~
->setListData($data_list) // 数据列表
~~~
6.设置列表分页。
~~~
->setListPage($total,12) // 数据列表分页
~~~
>[info] 注意:分页方法的第二个参数是设置每页的数据行数,要和数据查询的设置相同
7.添加列项按钮
~~~
->addRightButton('edit')
~~~
- 前言
- 基础
- 安装
- 规范
- 数据库设计
- 命名规范
- 建议参考
- 架构
- 架构总览
- 目录结构
- 生命周期
- 入口文件
- 模块设计
- 插件设计
- 主题设计
- API设计
- 容器和依赖注入
- 验证器设计
- 钩子和行为设计
- 介绍
- 后台介绍
- 仪表盘
- 系统设置
- 系统设置
- 网站设置
- 前台导航菜单
- 后台导航菜单
- 配置管理
- 用户管理
- 权限管理
- 角色组
- 节点管理
- 附件管理
- 工具
- 扩展中心
- 模块
- 插件
- 主题
- 前台介绍
- API接口
- 模型层
- 定义
- 逻辑层
- 定义
- 逻辑初始化
- 服务层
- 定义
- 二次开发
- 模块开发
- 介绍
- 1.结构目录
- 2.install安装目录文件
- info.json
- options.php
- menus.php
- unstall.sql
- install.sql
- 3.安装模块
- 模块函数与全局函数
- 其他
- 插件开发
- 介绍
- 定义入口文件
- 1.结构目录
- 2.install安装目录文件
- info.json
- options.php
- menus.php
- install.sql
- unstall.sql
- 3.实现钩子方法
- 4.安装插件
- 开发使用
- 插件控制器Controller
- 插件模型Model
- 插件逻辑层Logic
- 开发总结
- 主题开发
- 介绍
- 结构目录
- install安装目录
- info.json
- 主题变量
- 模块主题化
- 插件主题化
- CSS、JS静态资源引入
- 创建模版文件
- API开发
- 通用组件
- wangeditor编辑器
- 上传
- 实战开发
- 控制器
- 验证器
- 接口
- 创建自定义模版
- 数据库操作
- 通过接口上传文件
- 构建器Builder(重要)
- 表单Form
- 设置页面标题
- 表单项(调用方式)
- 文本框text
- 隐藏域hidden
- 文本区textarea
- 时间选择器datetime
- 图片选择器picture
- 多图片选择器pictures
- 图片上传image
- 文件上传file
- wang编辑器wangeditor
- 百度富文本编辑器ueditor
- 选择项
- 添加标签栏Tab
- 自定义头部工具栏
- 表单提交处理
- 列表List
- 设置页面标题
- 添加标签栏Tab
- 高级查询
- 查询构造器
- 添加列表搜索功能
- 添加批量操作
- 自定义头部工具
- 顶部新增按钮
- 顶部批量启用
- 顶部批量禁用
- 排序Sort
- 表单验证
- 插件-Builder构建器
- 命令行
- 配置
- 扩展专题
- 轻松识别客户端信息User Agent
- 字符串
- 数组
- 钩子、插件、模块相关方法
- 时间
- 请求(request)
- 附件
- 用户信息
- 前台用户
- 后台用户
- 微信(wechat模块)
- 专题
- 插件专题
- 微信支付
- 支付宝(即时到账)
- 微信小程序专题
- 微信模块
- 日志
- 后台行为日志
- 框架日志
- 自定义日志
- 常见问题集
- 附录
- 配置参考
- 常量参考
- 变量参考
- 更新日志
- 升级指导
- 关于
- 进阶
- 分布式数据库
- 分布式缓存
- 负载均衡
- Redis
- 分库分表