你打电话时isValid
on a Zend_Form
它将传递您传递给该方法的所有数据
$form->isValid(array('a' => 1, 'b' => 2));
您的自定义验证器将收到整个数组原始值。
验证器示例
class My_Validator_TwoVals implements Zend_Validate_Interface
{
public function getMessages()
{
return array();
}
public function isValid($value)
{
print_r(func_get_args());
}
}
表格示例
$f = new Zend_Form;
$a = $f->createElement('Text', 'a');
$b = $f->createElement('Text', 'b');
$b->addPrefixPath('My_Validator', '.', 'validate');
$b->addValidator('TwoVals');
$f->addElements(array($a, $b));
$f->isValid(array('a' => 1, 'b' => 2));
Output
Array
(
[0] => 2
[1] => Array
(
[a] => 1
[b] => 2
)
)
正如你所看到的,还有第二个参数传递给isValid
,这是 $context.其中包含剩余的值。
An 选择是将要匹配的第二个元素作为选项传递给验证器,例如
class My_Validator_TwoVals implements Zend_Validate_Interface
{
protected $a;
public function getMessages()
{
return array();
}
public function isValid($value)
{
var_dump($this->a->getValue());
}
public function __construct(Zend_Form_Element $a)
{
$this->a = $a;
}
}
Setup
$f = new Zend_Form;
$a = $f->createElement('Text', 'a');
$b = $f->createElement('Text', 'b');
$b->addPrefixPath('My_Validator', '.', 'validate');
$b->addValidator('TwoVals', false, array($a));
$f->addElements(array($a, $b));
$f->isValid(array('a' => 1, 'b' => 2));
然后将打印int(1)
。正如您所看到的,我们通过表单元素的 API 获取该值,因此您为验证器和过滤器配置的任何内容都将被应用,例如这不是原始值。您还可以将其设置为其他值等。
还可以看看Zend_Validate_Identical
了解 ZF 如何实现对其他表单元素的检查:
- http://framework.zend.com/svn/framework/standard/trunk/library/Zend/Validate/Identical.php http://framework.zend.com/svn/framework/standard/trunk/library/Zend/Validate/Identical.php