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


Field specific errors on repeated field

我需要根据情况在特定字段下显示错误。就我而言,可能有两个。分别为CCD_ 1和CCD_。当前,所有消息都显示在password.second字段下。

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

我试图通过{% for error in form.password.first.vars.errors %}{% for error in form.password.second.vars.errors %}分别生成错误,但失败了,因为我需要的两条错误消息只有在使用Password is empty0时才会呈现。我已经做了很长一段时间了,然后两手空空地回来了。实现如下,

我使用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>

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

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

您可以创建自定义验证约束。为了实现你想要的行为,我认为你需要它是一个类约束验证器,这样它就可以同时访问这两个字段,并可以对它们进行比较。然而,这将再次意味着错误会在比您想要的更高的级别上应用,因此可能不会起作用。

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

控制器

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