3

我有一个用于捕获电子邮件地址的表单元素。我Zend_Validate_EmailAddress在元素上使用它,它会生成对用户不太友好的错误消息。

我的第一步是指定对用户更友好的新消息,但有些检查根本不适合用户友好的消息。然后,我尝试isValid()在表单上运行后简单地清除这些消息并指定我自己的,但我发现的所有功能都不会清除这些消息。

我尝试过的和结果

  1. setErrorMessages()- 这里设置的值似乎完全被忽略了
  2. clearErrorMessages()- 似乎被忽略了
  3. setErrors()- 添加我的信息,但保留其他信息

这是在我的自定义视图脚本中显示错误的代码:

<?php if ($this->element->hasErrors()): ?>
    <?php echo $this->formErrors($this->element->getMessages()); ?>
<?php endif; ?>

我的解决方案

我将答案授予Gordon,因为他的解决方案是最完整的,但我最终addErrorMessage()在元素上使用了这样的函数:

$element->addValidator('EmailAddress', false, $this->_validate['EmailAddress'])
        ->addErrorMessage("'%value%' is not a valid email address");

$element->addValidator('Date', false, array('MM/dd/yyyy'))
        ->addErrorMessage("Date must be in MM/DD/YYYY format");
4

3 回答 3

5

从参考指南(强调我的):

一些开发人员可能希望为验证器提供自定义错误消息。该方法的$options参数Zend_Form_Element::addValidator()允许您通过提供键'messages'并将其映射到键/值对数组来设置消息模板来做到这一点。您需要知道特定验证器的各种验证错误类型的错误代码

所以你可以这样做:

$form = new Zend_Form;
$username = new Zend_Form_Element_Text('username');
$username->addValidator('regex', false, array(
    '/^[a-z]/i',
    'messages' => array(
        'regexInvalid'  => 'foo',
        'regexNotMatch' => 'bar',
        'regexErrorous' => 'baz'
    )
));
$form->addElement($username);
$form->isValid(array('username' => '!foo'));

然后它将为错误消息呈现“bar”,因为正则表达式不匹配,因为它不是以 aZ 的字母开头。

这相当于使用:

$username->setErrorMessages(
    array(
        'regexNotMatch' => 'The value %value% must start with a-Z',
        …
    )
);

我使用了不同的模式来说明如何在模式中使用已验证的值。

setErrors如果要删除任何默认模板,也可以使用,例如

$username->setErrors(array('The value must start with a-Z'));

无论您做什么,都必须使用isValid. 运行验证后,否则Zend_Form_Element 包含默认错误消息。我不知道有什么方法可以重置它(尽管有人可能想纠正我)。

进一步引用参考指南:

更好的选择是在表单中使用 Zend_Translate_Adapter。错误代码由默认的 Errors 装饰器自动传递给适配器;然后,您可以通过为验证器的各种错误代码设置翻译来指定自己的错误消息字符串。

所有验证消息都可以从文件中自定义

该文件应该在 中APPLICATION_PATH/resources/languages,但只要您告诉Zend_Translate在哪里可以找到它,它就可以真正放在任何地方。

于 2011-04-20T20:22:23.483 回答
1

攻击它的一种方法是通过扩展您计划使用的验证器并覆盖消息来创建自己的自定义验证器。例如,查看 Zend_Validate_Alnum,它看起来像这样:

class Zend_Validate_Alnum extends Zend_Validate_Abstract
{
    const INVALID      = 'alnumInvalid';
    const NOT_ALNUM    = 'notAlnum';
    const STRING_EMPTY = 'alnumStringEmpty';

    [ ... ]

    protected $_messageTemplates = array(
        self::INVALID      => "Invalid type given. String, integer or float expected",
        self::NOT_ALNUM    => "'%value%' contains characters which are non alphabetic and no digits",
        self::STRING_EMPTY => "'%value%' is an empty string",
    );

    [ ... ]
}

像这样覆盖$_messageTemplates您自己的类中的数组

class My_Validate_Alnum extends Zend_Validate_Alnum
{
    protected $_messageTemplates = array(
        self::INVALID      => "My invalid message",
        self::NOT_ALNUM    => "foo",
        self::STRING_EMPTY => "'%value%' is bar",
    );

    [ ... ]
}

然后不要使用 Zend_Validate_Alnum,而是使用 My_Validate_Alnum 作为您的验证器。自定义验证器的创建非常简单。

于 2011-04-20T19:23:34.733 回答
1

当您定义这样的表单元素时

$titel = new Zend_Form_Element_Text ( "titel" );
$titel->setLabel ( "Titel" )->setRequired ( true )
      ->addValidator ( 'regex', false, array ("/[\pL\pN_\-]+/" ) );

您可以在视图脚本中指定错误消息

<?php 
    $form = $this->form;
    $errorsMessages =$this->form->getMessages();
?>

<div>
    <label>Titel</label> <?php echo $form->titel->renderViewHelper()?>
    <?php 
           if(isset($errorsMessages['titel'])){
               echo "<p class='error'>There's something wrong!</p>";
           }
    ?>
</div>

我不知道这是否符合您的方式,但我真的很喜欢以这种方式定义我的表单;)

于 2011-04-20T19:10:58.637 回答