php – 修剪空格后在jQuery数据表中使用内联编辑进行验证
作者:互联网
使用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的基本知识.
如果需要,我将发布相应的客户端脚本.
当强制执行额外条件以防止将输入值提交到抽象层数据库时,似乎会触发其他验证器.在内联单元格编辑的情况下不应该发生这种情况.
什么是补救措施?
解决方法:
如果代码的唯一更改是您用注释突出显示的那些行,我怀疑问题是您使用嵌套的三元运算符. 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块而不是三元运算符你仍然有错误,那么我会调查你的客户端代码以确保没有其他任何改变(如果这不是你可以在问题中发布它解决你的问题.
标签:php,datatables,validation,datatables-1-10,inline-editing 来源: https://codeday.me/bug/20190706/1394901.html