## 工作表表头验证验证器
> 说明:
设置工作表表头验证验证器。在导入表单数据时,对预设验证规则的工作表表头字段数据进行验证。在设定的验证器中可以写字段自定义的验证方法,也可对工作表表头字段数据进行进一步处理(handleData操作)。默认筛选表单字段验证器为 `\yunj\Validate`
方法:`colsValidate($colsValidate)`
* 参数 **colsValidate** (必须)
* 类型一:callable 闭包
```php
colsValidate(function(){
// 返回`\yunj\Validate`或其子类的实例对象
return new TestValidate();
// 返回`\yunj\Validate`或其子类的全限定类名
return \demo\validate\TestValidate::class;
});
```
* 类型二:string
```php
// `\yunj\Validate`或其子类的全限定类名
colsValidate(\demo\validate\TestValidate::class);
```
* 验证环境scene:
* `row`:数据导入验证每行数据时的验证环境
注意:`$row["sheet"]` 为当前验证数据行所在工作表,仅在sheet设置时存在。
> 示例:
导入产品数据:`序列号(sn)`、`名称(name)`、`商户(mid)`...
* 验证器
```php
namespace app\demo\validate\product;
final class Import extends \yunj\Validate {
// 自定义验证方法,校验序列号唯一性
protected function snUnique($value,$rule = "",$data){
$isExist = Db::name("product")->where("sn","=",$value)->select();
if($isExist ) return "该序列号已存在";
return true;
}
protected function handleData(array $rawData, $scene): array {
$data = $rawData;
switch ($scene) {
case "row":
// 工作表。仅在sheet设置时存在$data["sheet"]
$sheet = $data["sheet"];
// 校验商户有效性,并获取商户数据添加到验证数据里
$merchant = Db::name("merchant")->where("id","=",$data["mid"])->select();
if(!$merchant ) throw_error_json("商户数据错误");
$data["merchant_data"] = $merchant;
break;
}
return $data;
}
}
```
* 导入构建器:
```php
$builder=YI('general_example')->cols(function($sheet){
$cols=[
'sn'=>['title'=>'序列号','verify'=>'require|snUnique'],
'name'=>['title'=>'名称','verify'=>'require|checkSn','desc'=>'只能输入汉字'],
'mid'=>['title'=>'商户','verify'=>'require|positiveInteger']
];
return $cols;
})
->colsValidate(\app\demo\validate\product\Import::class)
->row(function($rowData,$sheet){ // $sheet仅在sheet设置时存在其他情况为null
// 获取展商数据
$merchant = $rowData["merchant_data"];
// 业务处理...
});
```
- 序言
- 基础
- 安装
- 目录结构
- 配置
- 版本
- 控制器
- 使用说明
- 视图模板
- 使用说明
- 区块重写
- 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
- 附录
- 升级指导
- 更新日志