# 当前平台已停止维护,请尽快迁移至[云静Admin TP6](https://gitee.com/worklz/yunj-admin-tp6)
[https://gitee.com/worklz/yunj-admin-tp6](https://gitee.com/worklz/yunj-admin-tp6)
*****
## 表格构建器渲染输出
* **方法一:页面内只有单一表格时**
> 注意!此方法仅支持渲染一个表格构建器,不需要写视图文件
控制器代码示例如下:
```php
namespace app\demo\controller;
use yunj\Controller;
class FormDemo extends Controller {
public function demo(){
$builder=YT('demo')
->state([11=>'正常',22=>"回收站"])
->filter([
'name'=>['title'=>'姓名']
])
->toolbar(function($state){
$toolbar=['add'=>['type'=>'openPopup','title'=>'添加','icon'=>'layui-icon layui-icon-add-circle','url'=>url('add')]];
switch ($state){
case 11:
$toolbar+=[
22=>['type'=>'asyncEvent','title'=>'移入回收站','dropdown'=>true],
];
break;
case 22:
$toolbar+=[
11=>['type'=>'asyncEvent','title'=>'还原','dropdown'=>true],
33=>['type'=>'asyncEvent','title'=>'永久删除','dropdown'=>true],
];
break;
}
return $toolbar;
})
->defaultToolbar('filter','export','print')
->import(url("demo/importDemo/index"))
->cols(function($state){
$cols=[
'id'=>['type'=>'checkbox'],
'name'=>['title'=>'姓名'],
'create_time'=>['title'=>'添加时间', 'align'=>'center', 'hide'=>'mobile_hide_hide','templet'=>'datetime'],
'action'=>[
'title'=>'操作',
'templet'=>'action',
'options'=>[
'edit'=>['type'=>'openPopup','title'=>'详情','icon'=>'layui-icon layui-icon-survey','url'=>url('edit')]
]
]
];
switch ($state){
case 11:
$cols['action']['options']+=[
22=>['type'=>'asyncEvent','title'=>'移入回收站','dropdown'=>true],
];
break;
case 22:
$cols['action']['options']+=[
11=>['type'=>'asyncEvent','title'=>'还原','dropdown'=>true],
33=>['type'=>'asyncEvent','title'=>'永久删除','dropdown'=>true]
];
break;
}
return $cols;
})
->count(function($filter){
// 固定参数
$state=$filter['state'];
$ids=$filter['ids'];
// 筛选表单参数
$name=$filter['name'];
$whereArr=[];
$whereArr[]=$state?['state','eq',$state]:['state','neq',33];
if($ids) $whereArr[]=['id','in',$ids];
if($name) $whereArr[]=['name_cn','like','%'.$name.'%'];
$count = $this->model->getOwnCount($whereArr);
return $count;
})
->items(function ($limit_start,$limit_length,$filter,$sort){
// 固定参数
$state=$filter['state'];
$ids=$filter['ids'];
// 筛选表单参数
$name=$filter['name'];
$whereArr=[];
$whereArr[]=$state?['state','eq',$state]:['state','neq',33];
if($ids) $whereArr[]=['id','in',$ids];
if($name) $whereArr[]=['name_cn','like','%'.$name.'%'];
$orderArr=$sort+['id'=>'desc'];
$items = $this->model->getOwnRows(["*"],$whereArr,$orderArr,$limit_start,$limit_length);
return $items;
})
->event(function ($event,$ids){
foreach ($ids as $id){
$whereArr=[['id','eq',$id]];
switch ($event){
case 11:
$updateData=['state'=>11];
$whereArr[]=['state','eq',22];
break;
case 22:
$updateData=['state'=>22];
$whereArr[]=['state','eq',11];
break;
case 33:
$updateData=['state'=>33];
$whereArr[]=['state','eq',22];
break;
default:
return error_json();
}
if($updateData) $this->model->change($updateData,$whereArr);
}
return success_json();
});
return view_table($builder);
}
}
```
不需要视图文件!
* **方法二:自定义页面内容时**
> 注意!此方法支持一个页面渲染多个表格构建器,需要写视图文件
控制器代码示例如下:
```php
namespace app\demo\controller;
use yunj\Controller;
class FormDemo extends Controller {
public function demo(){
// 表格构建器配置参考方法一
$builder=YT('demo');
// 多个构建器可反复调用此方法 $builder->assign($this);
$builder->assign($this);
return $this->fetch();
}
}
```
视图代码示例如下:
```html
{extend name="$adminPage"}
{block name="content"}
<table type="yunj" id="demo"></table>
{/block}
```
- 序言
- 基础
- 安装
- 目录结构
- 配置
- 版本
- 控制器
- 使用说明
- 视图模板
- 使用说明
- 区块重写
- seo
- headStyle
- headScript
- content
- script
- 验证器
- TP验证器
- 使用说明
- 自动处理
- 数据处理
- 前端验证器
- 概述
- 调用示例
- 通用验证规则
- 表单构建器
- 基础示例
- 初始化
- 链式操作
- tab
- url
- field
- fieldValidate
- button
- load
- submit
- 渲染输出
- 字段配置
- 使用说明
- 隐藏域(hidden)
- 文本框(text)
- 文本域(textarea)
- 密码框(password)
- 富文本(editor)
- 文档编辑(markdown)
- 下拉选框(select)
- 单选框(radio)
- 复选框(checkbox)
- 开关(switch)
- 日期(date)
- 时间日期(datetime)
- 年份(year)
- 月份(month)
- 时间(time)
- 单图(img)
- 多图(imgs)
- 单文件(file)
- 多文件(files)
- 取色器(color)
- 地区联动(area)
- 下拉搜索(dropdownSearch)
- 树(tree)
- 自定义字段
- 单一字段调用
- 概述
- 示例
- 表格构建器
- 基础示例
- 初始化
- 链式操作
- state
- url
- page
- limit
- limits
- filter
- filterValidate
- toolbar
- defaultToolbar
- import
- cols
- count
- items
- event
- 渲染输出
- 表头配置
- 使用说明
- 枚举(enum)
- 时间日期(datetime)
- 单图(img)
- 多图(imgs)
- 单文件(file)
- 多文件(files)
- 拖拽排序(dragSort)
- 颜色呈现(color)
- 地区呈现(area)
- 操作栏(action)
- 自定义表头
- JS事件
- 异步事件监听
- 导入构建器
- 基础示例
- 初始化
- 链式操作
- sheet
- cols
- colsValidate
- limit
- tips
- row
- rows
- 渲染输出
- 主题开发
- 实现步骤
- 系统主题
- 注意
- PHP公共方法库
- 配置
- yunj_config
- 构建器
- YF
- YT
- YI
- 重定向
- url_tips
- redirect_tips
- throw_redirect
- 响应输出
- response_msg
- response_json
- success_json
- error_json
- throw_json
- throw_success_json
- throw_error_json
- 数组
- array_eq
- array_in
- array_supp
- array_depth
- array_insert
- array_key_prefix
- 验证
- is_mobile
- is_positive_int
- is_positive_integer
- is_json
- is_datetime
- is_md5_result
- 时间日期
- msectime
- 字符串
- rand_char
- filter_sql
- start_with
- exception_to_str
- 数据加解密
- aes_encrypt
- aes_decrypt
- rsa_encrypt
- rsa_decrypt
- rsa_sign
- rsa_sign_verify
- JS公共方法库
- 调用说明
- 数据类型
- varType
- 判断
- isMobile
- isObj
- isEmptyObj
- isArray
- isEmptyArray
- isString
- isEmptyString
- isBool
- isNumber
- isFloat
- isFunction
- isUndefined
- isJson
- isCsv
- isXls
- isXlsx
- 字符串
- fileExt
- fileNameExt
- currTimestamp
- currDatetime
- timestampFormat
- 对象
- objSupp
- 图片
- previewImg
- url
- url
- urlParam
- urlPushParam
- 页面
- openNewPage
- openTab
- openPopup
- rawPageWin
- redirectTab
- redirectLogin
- isPopupPage
- isTabPage
- currPageId
- close
- closeCurr
- closeAll
- 网络
- request
- 数据加解密
- aesEncrypt
- aesDecrypt
- rsaEncrypt
- rsaDecrypt
- rsaSign
- rsaSignVerify
- 附录
- 升级指导
- 更新日志