我需要根据具体情况在特定字段下显示错误。在我的情况下,可以有两个。哪些是Password is empty
和Passwords 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
字段来实施password
和confirm 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>
答案 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!") );
}
// ...