使用jQuery数据表编辑器插件,以下代码按预期工作。它执行指定的验证(为简洁起见,省略了一些字段)。
Editor::inst( $db, 'file_upload' )
->fields(
Field::inst( 'id' )->validator( 'Validate::notEmpty' ),
Field::inst( 'name' )->validator( 'Validate::notEmpty' )
->validator( function ($val, $data, $opts) {
$length = strlen(trim(preg_replace('/\s+/', ' ', $val)));
return $length > 30 ? 'Length must be 30 characters or less' : true;
})->getFormatter( function ( $val, $data, $opts ) {
return htmlspecialchars($val, ENT_QUOTES, "UTF-8");
})->setFormatter( function ( $val, $data, $opts ) {
return trim(preg_replace('/\s+/', ' ', $val));
}),
Field::inst( 'document_title' )->validator( 'Validate::notEmpty' )
->validator( function ($val, $data, $opts) {
$length = strlen(trim(preg_replace('/\s+/', ' ', $val)));
return $length > 50 ? 'Length must be 50 characters or less' : true;
})->getFormatter( function ( $val, $data, $opts ) {
return htmlspecialchars($val, ENT_QUOTES, "UTF-8");
})->setFormatter( function ( $val, $data, $opts ) {
return trim(preg_replace('/\s+/', ' ', $val));
}),
Field::inst( 'email_address' )->validator( 'Validate::notEmpty' )
->validator( function ($val, $data, $opts) {
$length = strlen(trim(preg_replace('/\s+/', ' ', $val)));
return $length > 60 ? 'Length must be 60 characters or less' : true;
})->getFormatter( function ( $val, $data, $opts ) {
return htmlspecialchars($val, ENT_QUOTES, "UTF-8");
})->setFormatter( function ( $val, $data, $opts ) {
return trim(preg_replace('/\s+/', ' ', $val));
})
)->where( function ( $q ) {
$q->where( 'file_type', "('jpg', 'jpeg', 'gif', 'png')", 'IN', false );
})->process( $_POST )
->json();
但是当稍微修改验证逻辑时,如下所示,
Editor::inst( $db, 'file_upload' )
->fields(
Field::inst( 'id' )->validator( 'Validate::notEmpty' ),
Field::inst( 'name' )->validator( 'Validate::notEmpty' )
->validator( function ($val, $data, $opts) {
$length = strlen(trim(preg_replace('/\s+/', ' ', $val)));
// The following line has been modified
return $length === 0 ? 'This field is required' : ($length > 30 ? 'Length must be 30 characters or less' : true);
})->getFormatter( function ( $val, $data, $opts ) {
return htmlspecialchars($val, ENT_QUOTES, "UTF-8");
})->setFormatter( function ( $val, $data, $opts ) {
return trim(preg_replace('/\s+/', ' ', $val));
}),
Field::inst( 'document_title' )->validator( 'Validate::notEmpty' )
->validator( function ($val, $data, $opts) {
$length = strlen(trim(preg_replace('/\s+/', ' ', $val)));
// The following line has been modified
return $length === 0 ? 'This field is required' : ($length > 50 ? 'Length must be 50 characters or less' : true);
})->getFormatter( function ( $val, $data, $opts ) {
return htmlspecialchars($val, ENT_QUOTES, "UTF-8");
})->setFormatter( function ( $val, $data, $opts ) {
return trim(preg_replace('/\s+/', ' ', $val));
}),
Field::inst( 'email_address' )->validator( 'Validate::notEmpty' )
->validator( function ($val, $data, $opts) {
$length = strlen(trim(preg_replace('/\s+/', ' ', $val)));
// The following line has been modified
return $length === 0 ? 'This field is required' : ($length > 60 ? 'Length must be 60 characters or less' : true);
})->getFormatter( function ( $val, $data, $opts ) {
return htmlspecialchars($val, ENT_QUOTES, "UTF-8");
})->setFormatter( function ( $val, $data, $opts ) {
return trim(preg_replace('/\s+/', ' ', $val));
})
)->where( function ( $q ) {
$q->where( 'file_type', "('jpg', 'jpeg', 'gif', 'png')", 'IN', false );
})->process( $_POST )
->json();
在这种情况下,将按原样执行验证,但不会向数据库提交值(并且数据表不会同时更新)。按下回车键后,内联编辑文本框仍保持打开状态。
可能是什么原因以及如何解决?可能,我遗漏了一些关于PHP的基本知识。
如果需要,我会发布相应的客户端脚本。
当强制执行额外条件以防止将输入值提交到抽象层数据库时,似乎会触发其他验证程序。在内联单元格编辑的情况下不应该这样做。
补救措施是什么?
答案 0 :(得分:1)
如果代码的唯一更改是您用注释突出显示的那些行,我怀疑问题是您使用嵌套的三元运算符。 PHP标记中的这些two单独questions可能会清除一些内容,但基本上快速版本是PHP三元运算符有一些奇怪的行为,因此不建议使用它们嵌套。我建议您尝试切换到标准的if / else语句,看看是否能解决您的问题,所以
if($length === 0){
return 'This field is required';
}
else if($length > 50){
return 'Length must be 50 characters or less';
}
else{
return true;
}
虽然这可能会更长,但调试可能会容易得多,我怀疑根据您的问题,如果这一切都被改变了,那么问题就归结为left-associative ternary operator nesting;而在所有其他语言中,三元运算符是右关联的。
这里one more link推荐PHP中的嵌套三元运算符。
在提交提交后保持打开的文本框是DataTables JavaScript表单错误的标准,这在CRUD操作服务器端没有向客户端返回预期值时很常见(检查浏览器开发人员控制台以确保您不会这样做)。得到一个JS错误,如果你想要一个非常强大的版本,我建议你使用Firebug for Firefox)。如果修改你的代码后使用if / else块而不是三元运算符你仍然有错误,那么我会查看你的客户端代码,以确保没有其他任何改变(如果这不是,那么你可以在问题中发布它#39;解决你的问题。)