我刚开始使用Twig,我正在尝试建立一个注册表单.要添加密码/重新输入密码字段,我使用"重复"文件类型:
->add('password', 'repeated', array(
'type' => 'password',
'invalid_message' => 'Passwords have to be equal.',
'first_name' => 'Password',
'second_name' => 'Re-enter password',
));
Run Code Online (Sandbox Code Playgroud)
按预期工作.但问题是,我想在表单中添加一些自定义类等.所以我的模板看起来像这样:
<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>
Run Code Online (Sandbox Code Playgroud)
这适用于除密码部分之外的所有内容.我想分别渲染两个字段,现在它们只是在同一个div中渲染.
我该如何解决?有没有办法在Twig中选择单独的字段?或者我只是做错了,因为我首先遇到了这个问题.
teu*_*oon 57
随机猜测后我解决了自己的问题.我会在这里发布,所以其他可能通过搜索来回答这个问题的人也知道答案:
{% 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 %}
Run Code Online (Sandbox Code Playgroud)
小智 27
如果你想从你的树枝模板中的重复方法中分离两个密码字段,你只需回调它们各自的名字,如:
{{ form_label(form.password.pass, "Password :") }}
{{ form_widget(form.password.pass) }}
{{ form_label(form.password.confirm, "Confirm :") }}
{{ form_widget(form.password.confirm) }}
Run Code Online (Sandbox Code Playgroud)
当然在你的功能:
/..
->add('password', 'repeated', array(
'first_name' => 'pass',
'second_name' => 'confirm',
'type' => 'password'
))
Run Code Online (Sandbox Code Playgroud)
问候.
csl*_*ano 20
这对我有用:
....
{{ 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>
....
Run Code Online (Sandbox Code Playgroud)