Подтвердить что ты не робот

Пользовательский рендеринг "повторного" поля из Symfony 2 в Twig

Я только начал использовать Twig, и я пытаюсь создать регистрационную форму. Чтобы добавить пароль/повторно ввести поле пароля, я использую "повторяющийся" тип файла:

->add('password', 'repeated', array(
    'type' => 'password',
    'invalid_message' => 'Passwords have to be equal.',
    'first_name'      => 'Password',
    'second_name'     => 'Re-enter password',
));

который работает по назначению. Однако проблема заключается в том, что я хочу добавить в свою форму некоторые пользовательские классы и т.д. Поэтому мой шаблон выглядит так:

<form action="{{ path('register') }}" method="post" {{ form_enctype(form) }}>
    {{ form_errors(form) }}
    {{ form_errors(form.username) }}
    <div class="form-field">
        {{ form_label(form.username, null, { 'attr': {'class': 'form-label'} }) }}
        {{ form_widget(form.username, { 'attr': {'class': 'form-input'} }) }}
    </div>
    {{ form_errors(form.email) }}
    <div class="form-field">
        {{ form_label(form.email, null, { 'attr': {'class': 'form-label'} }) }}
        {{ form_widget(form.email, { 'attr': {'class': 'form-input'} }) }}
    </div>
    {{ form_errors(form.password) }}
    <div class="form-field">
        {{ form_label(form.password, null, { 'attr': {'class': 'form-label'} }) }}
        {{ form_widget(form.password, { 'attr': {'class': 'form-input'} }) }}
    </div>

    {{ form_rest(form) }}

    <input type="submit" class="contact-submit" />
</form>

это отлично работает для всего, кроме части пароля. Я хочу сделать оба поля отдельно, теперь они оба отображаются в одном div.

Как это исправить? Есть ли способ выбрать отдельные поля в Twig? Или я просто делаю что-то неправильно, потому что сталкиваюсь с этой проблемой в первую очередь.

4b9b3361

Ответ 1

После случайной догадки я решил свою проблему. Я отправлю его здесь, чтобы другие, которые могли бы подойти к этому вопросу, выполнив поиск, также знают ответ:

{% for passwordField in form.password %}
    <div class="form-field">
        {{ form_label(passwordField, null, { 'attr': {'class': 'form-label'} }) }}
        {{ form_widget(passwordField, { 'attr': {'class': 'form-input'} }) }}
    </div>
{% endfor %}

Ответ 2

Если вы хотите отделить оба поля паролей от повторного метода в своем шаблоне ветки, вам просто нужно перезвонить их соответствующие имена, например:

{{ form_label(form.password.pass, "Password :") }}
{{ form_widget(form.password.pass) }}

{{ form_label(form.password.confirm, "Confirm :") }}
{{ form_widget(form.password.confirm) }}

И, конечно же, в вашей функции:

/..
->add('password', 'repeated', array(
'first_name' => 'pass',
'second_name' => 'confirm',
'type' => 'password'
))

С уважением.

Ответ 3

Это работает для меня:

....
{{ form_errors(form.password.first) }}
<div class="form-field">
    {{ form_label(form.password.first, null, { 'attr': {'class': 'form-label'} }) }}
    {{ form_widget(form.password.first, { 'attr': {'class': 'form-input'} }) }}
</div>

{{ form_errors(form.password.second) }}
<div class="form-field">
    {{ form_label(form.password.second, null, { 'attr': {'class': 'form-label'} }) }}
    {{ form_widget(form.password.second, { 'attr': {'class': 'form-input'} }) }}
</div>
....

Ответ 4

Если вы используете Bundle пользователей, они используют password.first и password.second, еще лучше попробуйте использовать ваш профилировщик, чтобы увидеть, какие переменные поступают из представления и контроллеров;)

Ответ 5

Если вы хотите иметь широкие классы приложений для ваших ярлыков и входов, вы можете настроить способ отображения меток и виджетов. Проверьте http://symfony.com/doc/current/cookbook/form/form_customization.html

Если вы посмотрите на этот файл:

vendor/symfony/src/Symfony/Bridge/Twig/Resources/views/Form/form_div_layout.html.twig

Вы можете видеть значения по умолчанию для всех виджетов. Чтобы добиться именно того, что вам нужно, вы можете переопределить блок generic_label для добавления класса метки метки:

{% block generic_label %}
{% spaceless %}
    {% if required %}
        {# We add form-label class in the next line! #}
        {% set attr = attr|merge({'class': attr.class|default('') ~ ' required form-label'}) %}
    {% endif %}
    <label{% for attrname,attrvalue in attr %} {{attrname}}="{{attrvalue}}"{% endfor %}>{{ label|trans }}</label>
{% endspaceless %}
{% endblock %}

И блок widget_attributes для добавления класса ввода форм:

{% block widget_attributes %}
{% spaceless %}
    {# We add form-input class in the next line! #}
    {% set attr = attr|merge({'class': attr.class|default('') ~ ' form-input'}) %}
    id="{{ id }}" name="{{ full_name }}"{% if read_only %} 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 %}{{attrname}}="{{attrvalue}}" {% endfor %}
{% endspaceless %}
{% endblock widget_attributes %}

С этими двумя шаблонами все ваши входы должны визуализировать с помощью классов, которые вам нужны, без необходимости повторять параметры attr по всем формам.

Я не пробовал, но это должно заботиться о проблеме повторного поля. Даже если это не так, вы можете создать шаблон repeat_widget и/или repeat_row, чтобы настроить, как визуализирует повторяющийся виджет, тем самым фиксируя этот виджет для всех форм, которые его используют.