最近我面临如下情况:
有一个三个输入的表单。它们都具有相关的数据库属性(值)。 现在:至少需要其中一个,但可以是其中任何一个。
最聪明的方法(最好遵循Kohana和/或ORM的指导方针)是什么? 我希望这个“规则”存储在模型中,而不是存储在控制器中。
到目前为止,我已设法将自定义规则应用于所有三个字段,但这会导致三个错误消息,每个字段一个。
如果需要更多详细信息,请告知我们。
答案 0 :(得分:1)
我认为这就是你需要的
// File: application/classes/helper/validation.php
class Helper_Validation {
public static function one_not_empty($array, $keys)
{
if( ! is_array($keys))
{
// throw new Exception('Helper_Validation::one_not_empty expects an array');
return FALSE;
}
foreach($keys as $key)
{
// Change this IF to whatever is the required value
if(Arr::get($array, $key) !== NULL)
{
return TRUE;
}
}
return FALSE;
}
}
现在将其应用于所有领域:
$keys = array('field1', 'field2', 'field3');
$validation = Validation::factory($array)
->rule('field1', 'Helper_Validation::one_not_empty', array($keys))
->rule('field2', 'Helper_Validation::one_not_empty', array($keys))
->rule('field3', 'Helper_Validation::one_not_empty', array($keys));
我认为这应该有效,但未经测试,请告诉我们:)
答案 1 :(得分:1)
试试这个
public function rules(){
return array(
'field1' => array(
array('at_least', array($this, 1, array('field1', 'field2', 'field3'))),
),
'field2' => array(
array('at_least', array($this, 1, array('field1', 'field2', 'field3'))),
),
'field3' => array(
array('at_least', array($this, 1, array('field1', 'field2', 'field3'))),
),
);
}
public static function at_least($array, $needed = 1, $fields){
$found = 0;
foreach ($fields as $field){
if (isset($array[$field]) AND Valid::not_empty($array[$field])){
$found++;
}
}
return ($found >= $needed);
}