在symfony2中将类添加到无效的表单错误

Joh*_*auß 7 php forms validation symfony

我想在symfony2表单中自定义错误处理.如果发生错误,输入字段应该有另一个类来显示输入值不正确.

我怎样才能做到这一点?我知道我必须自定义渲染模板,但我真的不知道如何做到这一点.我是否必须自定义所有输入模板?如果输入包含错误,我该如何检查?

g.a*_*dam 12

如果你不想使用自定义表单,那么你可以做这样的事情(我有Symfony 2.6和Bootstrap 3):

    <div class="form-group {% if not form.YOUR_ELEMENT.vars.valid %}has-error{% endif %}">
        {{ form_label(form.YOUR_ELEMENT) }}
        {{ form_widget(form.YOUR_ELEMENT) }}
    </div>
Run Code Online (Sandbox Code Playgroud)


小智 6

这是我的自定义表单主题的解决方案.我复制了标准widget_attributes块并在{# ADD ERROR START #}和之间添加了代码{# ADD ERROR END #}.您只需要将值替换为{% set errorClass = 'error' %}错误类.

此解决方案将指定的错误类添加到所有有错误的小部件.

{% block widget_attributes %}
    {% spaceless %}
        {# ADD ERROR START #}
        {% if errors|length > 0 %}
            {% set errorClass = 'error' %}
            {% if attr.class is defined %}
                {% set errorClass = errorClass ~ ' ' ~ attr.class %}
            {% endif %}
            {% set attr = attr|merge({'class': errorClass}) %}
        {% endif %}
        {# ADD ERROR END #}
        id="{{ id }}" name="{{ full_name }}"
        {%- if read_only %} readonly="readonly"{% endif -%}
        {%- if disabled %} disabled="disabled"{% endif -%}
        {%- if required %} required="required"{% endif -%}
        {%- if max_length %} maxlength="{{ max_length }}"{% endif -%}
        {%- if pattern %} pattern="{{ pattern }}"{% endif -%}
        {%- for attrname, attrvalue in attr -%}
            {{- " " -}}
            {%- if attrname in ['placeholder', 'title'] -%}
                {{- attrname }}="{{ attrvalue|trans({}, translation_domain) }}"
            {%- elseif attrvalue is sameas(true) -%}
                {{- attrname }}="{{ attrname }}"
            {%- elseif attrvalue is not sameas(false) -%}
                {{- attrname }}="{{ attrvalue }}"
            {%- endif -%}
        {%- endfor -%}
    {% endspaceless %}
{% endblock widget_attributes %}
Run Code Online (Sandbox Code Playgroud)


smo*_*eno 3

您可以使用表单主题并覆盖默认主题。前任。了解MopaBootstrapBundle主题如何使用 Twitter Bootstrap 理念完全应用您想要的。