重复字段上的字段特定错误

时间:2014-10-13 05:35:42

标签: php forms validation symfony error-handling

我需要根据具体情况在特定字段下显示错误。在我的情况下,可以有两个。哪些是Password is emptyPasswords do not match。目前,所有消息都显示在password.second字段下。

我需要在Password is empty字段下显示password.first错误,在Passwords don not match字段下显示password.second

我尝试通过{% for error in form.password.first.vars.errors %}{% for error in form.password.second.vars.errors %}分别生成错误,但失败了,因为我要求的两条错误消息仅在我使用{% for error in form.password.vars.errors %}时呈现。我已经待了很长一段时间,空手而归。实施如下,

我正在使用repeated字段来实施passwordconfirm password,如下所示,

$builder->add( 'password', 'repeated', array( 'type' => 'password','required' => true,  'invalid_message' => ErrorMessages::PASSWORDS_DO_NOT_MATCH, 'options' => array('attr' => array('class' => 'password-field form-control')),'first_options'  => array('label' => false,'error_bubbling' => true,'label_attr'=>array('class'=>'col-sm-4 control-label')),'second_options' => array('label' => false,'label_attr'=>array('class'=>'col-sm-4 control-label')))); 

password entity验证如下,

class User implements UserInterface, \Serializable {    

  /**
   * @Assert\Email(message=ErrorMessages::EMAIL_ADDRESS_INVALID)
   * @Assert\NotBlank(message=ErrorMessages::EMAIL_ADDRESS_EMPTY)
   */
  private $email;

  /**     
   * @Assert\NotBlank(message=ErrorMessages::PASSWORD_EMPTY, groups={"full"})
   */
  private $password;
  ....

我以下列方式在twig中渲染这两个字段,

<div class="form-group {% if form.password.vars.errors|length > 0 %}has-error{% endif %} {% if form.password.vars.required == 'true' %}required{% endif %}">
  {{ form_label(form.password.first, "Password") }}
  <div class="col-sm-8">
    {{ form_row(form.password.first) }}                      
  </div>              
</div>
<div class="form-group {% if form.password.vars.errors|length > 0 %}has-error{% endif %} {% if form.password.vars.required == 'true' %}required{% endif %}">
  {{ form_label(form.password.second, "Confirm password") }}
  <div class="col-sm-8">
    {{ form_row(form.password.second) }}
    <span class="help-block">
      {% for error in form.password.vars.errors %}
        {{ error.messageTemplate|trans(error.messageParameters, 'validators')~'' }}
      {% endfor %}
    </span>
  </div>
</div>

1 个答案:

答案 0 :(得分:1)

如果您想使用方便的repeated字段,那么您可能会卡住 - repeated的工作方式是使用ValueToDuplicatesTransformer复制您添加到两个字段中的字段相同的数据,并确保它们在Transformer将提交的表单值转换回模型数据(不使用常规约束)的位置相同。从验证的PoV开始,只有一个字段,因此您无法选择错误所针对的文本框。

但如果你想自己解决这个问题,可能会有其他选择!

你可以制作Custom Validation Constraint。为了实现您认为自己需要它为Class Constraint Validator之后的行为,以便它可以同时访问这两个字段,并可以比较它们。但是,这将再次意味着错误应用于您想要的更高级别,因此可能无法正常工作。

因此,可能的方法是手动测试Controller中的字段,并将相关错误直接添加到您希望与之关联的字段中,如下所示。您需要将密码字段拆分为两个,以便可以相互测试它们,因此将NotBlank约束放在第一个字段上。

控制器

// ...

$password1 = $form->get('password1');
$password2 = $form->get('password2');
if ($password1->getData() != $password2->getData() )
{
    $password2->addError(new FormError("Passwords do not match!") );
}

// ...