【发布时间】:2016-05-19 14:49:42
【问题描述】:
我有一个带有数组字段的表单,允许用户选择多个类别 ID。他们必须至少选择一个类别,但可以选择多个类别。我的表单验证需要确保至少指定一个类别 ID,然后对于每个类别 ID,它需要检查它是否是有效类别。这是我所拥有的:
$this->form_validation->set_rules('event_categories', 'Categories', 'required');
$this->form_validation->set_rules('event_categories[]', 'Categories', 'integer|exists[category.id]');
我已经扩展了表单验证库并添加了exists方法,如下所示:
/**
* Checks to see if a value exists in database table field
*
* @access public
* @param string
* @param field
* @return bool
*/
public function exists($str, $field)
{
//die("fe");
list($table, $field)=explode('.', $field);
$query = $this->CI->db->limit(1)->get_where($table, array($field => $str));
if($query->num_rows() !== 0) {
return TRUE;
}
else {
if(!array_key_exists('exists',$this->_error_messages)) {
$this->CI->form_validation->set_message('exists', "The %s value does not exist");
}
return FALSE;
}
}
问题是即使我提交了一个有效的类别 ID 数组,表单验证在所需的检查中也失败了,并且说我必须提交一些,即使我已经提交了。
【问题讨论】:
标签: php codeigniter codeigniter-3