使用 Symfony2(.7) 减少 Twig 中的表单组布局
Reduce form groups layout in Twig with Symfony2(.7)
我正在尝试摆脱 symfony2 表单在 twig 中的重复布局
目前我的布局看起来像:
<form name="step2" method="post" action="" class="productForm">
<h2>Step2:</h2>
<div id="step2">
<div class="form-group">
<div class="form-widget">
<div id="step2_client1">
<div class="form-group"><label class="control-label required" for="step2_client1_clientTitle">Client 1 title:</label>
<div class="form-widget"><select id="step2_client1_clientTitle" name="step2[client1][clientTitle]" class="form-control">
<option value="Mr">Mr</option>
<option value="Mrs">Mrs</option>
<option value="Miss">Miss</option>
<option value="Ms">Ms</option>
<option value="Dr">Dr</option>
<option value="Sir">Sir</option>
</select></div>
</div>
<div class="form-group"><label class="control-label required" for="step2_client1_firstName">Client 1 first name:</label>
<div class="form-widget"><input type="text" id="step2_client1_firstName" name="step2[client1][firstName]" required="required" class="form-control">
</div>
</div>
<div class="form-group"><label class="control-label required" for="step2_client1_surname">Client 1 last name:</label>
<div class="form-widget"><input type="text" id="step2_client1_surname" name="step2[client1][surname]" required="required" class="form-control"></div>
</div>
</div>
</div>
</div>
...
<div class="form-group form-group-submit">
<div class=""><a id="step2_save" class="has-spinner btn btn-default btn-submit"><span class="spinner"><i class="fa fa-spinner fa-spin"></i></span>Complete the quote
</a></div>
</div>
<input type="hidden" id="step2__token" name="step2[_token]" class="form-control" value="xxx"></div>
</form>
我有一个肮脏的 js 脚本来按照我希望它显示的方式修复我的布局,但如前所述,这是肮脏的。所以我想知道是否有人可以帮我改变我的树枝文件,只显示 form-group 和 form-widget css 类 用于子元素而不是父元素。
肮脏的js脚本:
$('.form-group').each(function(e){
if($(this).parents('.form-group').length) {
var $realGroup = $(this).parents('.form-group');
$realGroup.toggleClass('form-group');
$realGroup.children('.form-widget').toggleClass('form-widget');
}
});
还有树枝位:
{% block form_row -%}
{% spaceless %}
<div class="form-group{% if (not compound or force_error|default(false)) and not valid %} has-error{% endif %}">
{{ form_label(form) }}
<div class="form-widget">
{{ form_widget(form) }}
{{ form_errors(form) }}
</div>
</div>
{% endspaceless %}
{%- endblock form_row %}
现在 twig 位是标准的 SF2 bootstrap 表单布局,我很确定我没有改变它。
因此,任何帮助摆脱 js 脚本并实际在 twig 中执行它的方法都会很棒,我尝试了一些方法,但每一个都比我用 js 所做的更糟糕,所以我有点卡。
编辑:
js 脚本所做的只是删除 css 类,因此布局有效。它看起来很平坦,因为它只是空的 div,但我所追求的并不是首先显示 div。我正在尝试更改 twig 脚本,而不是 css,因为这正是我们想要的方式。
你有三个选择。
1.Either 手动创建每个字段:
{{ form_start(form, {'action': path(''), 'attr': {'class':'productForm'}}) }}
{{ form_errors(form) }}
<div class="form-group">
{{ form_label(form.clientTitle, 'Client 1 title:', {'label_attr': {'class': 'control-label required'}}) }}
<div class="form-widget">
{{ form_widget(form.clientTitle, { 'attr': {'class': 'form-control' }}) }}
</div>
{{ form_errors(form.clientTitle) }}
</div>
<div class="form-group">
{{ form_label(form.firstName, 'Client 1 first name:', {'label_attr': {'class': 'control-label required'}}) }}
<div class="form-widget">
{{ form_widget(form.firstName, { 'attr': {'class': 'form-control' }}) }}
</div>
{{ form_errors(form.firstName) }}
</div>
<div class="form-group">
{{ form_label(form.firstName, 'Client 1 last name:', {'label_attr': {'class': 'control-label required'}}) }}
<div class="form-widget">
{{ form_widget(form.firstName, { 'attr': {'class': 'form-control' }}) }}
</div>
{{ form_errors(form.firstName) }}
</div>
<div class="form-group form-group-submit">
<div class="">
<a id="step2_save" class="has-spinner btn btn-default btn-submit">
<span class="spinner">
<i class="fa fa-spinner fa-spin"></i>
</span>
Complete the quote
</a>
</div>
</div>
{{ form_end(change_password) }}
2.Or 您可以创建自己的 form theme.
3.Or 为每个表单使用一个循环:
{% for child in form.children %}
<div class="form-group">
{{ form_label(child, null, {'label_attr': {'class': 'control-label required'}}) }}
<div class="form-widget">
{{ form_widget(child, { 'attr': {'class': 'form-control' }}) }}
</div>
{{ form_errors(child) }}
</div>
{% endfor %}
这完全取决于您未来的表单会有多少字段以及您有多少相似的表单。
但是,用 JS 做这种事情是不行的。
George Irimiciuc 已经帮助你了,我的意思是你可以使用 George answer 中提供的第二个选项,你需要关注表单主题的这一部分。
Symfony2 twig 根据所选主题创建表单,如果您尝试添加您的表单主题那么它会很好,其他选项意味着您只是将问题推到其他地方,这只是一个技巧。无需更新完整的表格,只需添加您的 form_row 即可,可以试试这个
http://symfony.com/doc/current/cookbook/form/form_customization.html#customizing-the-form-row
我用过这是我的项目,最好的一点是你可以从你的表单构建器发送属性哪些字段,然后检查 form_row 下的那些,这会呈现你的表单行并可以创建你想要的表单检查条件后 -
attr => array( 'parent_class' => false)
并且可以在 form_row 下查看
if( form.vars.attr.parent_class is defined )
并且可以在树枝中添加条件。
如果您遇到问题,例如您的表单有子表单和树枝 form_row 以奇怪的方式显示 -
我构建了这个项目,直到现在只有这个,因为有学生实体与各种实体相结合,所以在像个人资料这样的表单条目时。我同时使用了实体 Student 和 Address 我所做的是,我只是检查了这个
{% if ( not form.children ) or ( form.vars.expanded is defined and form.vars.expanded ) %}
<div class="{{ form.vars.attr['parent-div-class'] is defined ? form.vars.attr['parent-div-class'] : 'col-sm-12'}}">
<div class="form-group">
{{ form_label(form) }}
{{ form_widget(form) }}
{% if form_errors(form) %}
{{ form_errors(form) }}
{% endif %}
</div>
</div>
{% else %}
<div class="clear-both"></div>
{{ form_label(form) }}
{{ form_widget(form) }}
{% endif %}
代码并不完全像这样,但主要概念是。
希望你明白我的意思。
最简单的方法是创建自定义表单主题。
如果你看at the current Symfony2's bootstrap one,你可以看到:
{% block form_row -%}
<div class="form-group{% if (not compound or force_error|default(false)) and not valid %} has-error{% endif %}">
{{- form_label(form) -}}
{{- form_widget(form) -}}
{{- form_errors(form) -}}
</div>
{%- endblock form_row %}
"copound" 的东西实际上是告诉你当前元素是否包含 sub-elements (表单,集合,......基本上所有 parent 元素),如果你不想要 form-group
class parents,你只需要在自定义主题中重载这个块。
{# AppBundle::custom_theme.html.twig #}
{% use "bootstrap_3_layout.html.twig" %}
{% block form_row -%}
<div class="{% if not compound %}form-group{% endif %}{% if (not compound or force_error|default(false)) and not valid %} has-error{% endif %}">
{{- form_label(form) -}}
{{- form_widget(form) -}}
{{- form_errors(form) -}}
</div>
{%- endblock form_row %}
如果您根本不需要 div,请将其删除!现在就开始吧。
要在整个项目中应用更改,您可以在 config.yml
中添加:
twig:
# ...
form_themes:
- 'AppBundle::custom_theme.html.twig'
或仅在特定视图上使用它:
{% form_theme yourForm 'AppBundle::custom_theme.html.twig' %}
注意:yourForm
是您当前的状态 object。
我正在尝试摆脱 symfony2 表单在 twig 中的重复布局 目前我的布局看起来像:
<form name="step2" method="post" action="" class="productForm">
<h2>Step2:</h2>
<div id="step2">
<div class="form-group">
<div class="form-widget">
<div id="step2_client1">
<div class="form-group"><label class="control-label required" for="step2_client1_clientTitle">Client 1 title:</label>
<div class="form-widget"><select id="step2_client1_clientTitle" name="step2[client1][clientTitle]" class="form-control">
<option value="Mr">Mr</option>
<option value="Mrs">Mrs</option>
<option value="Miss">Miss</option>
<option value="Ms">Ms</option>
<option value="Dr">Dr</option>
<option value="Sir">Sir</option>
</select></div>
</div>
<div class="form-group"><label class="control-label required" for="step2_client1_firstName">Client 1 first name:</label>
<div class="form-widget"><input type="text" id="step2_client1_firstName" name="step2[client1][firstName]" required="required" class="form-control">
</div>
</div>
<div class="form-group"><label class="control-label required" for="step2_client1_surname">Client 1 last name:</label>
<div class="form-widget"><input type="text" id="step2_client1_surname" name="step2[client1][surname]" required="required" class="form-control"></div>
</div>
</div>
</div>
</div>
...
<div class="form-group form-group-submit">
<div class=""><a id="step2_save" class="has-spinner btn btn-default btn-submit"><span class="spinner"><i class="fa fa-spinner fa-spin"></i></span>Complete the quote
</a></div>
</div>
<input type="hidden" id="step2__token" name="step2[_token]" class="form-control" value="xxx"></div>
</form>
我有一个肮脏的 js 脚本来按照我希望它显示的方式修复我的布局,但如前所述,这是肮脏的。所以我想知道是否有人可以帮我改变我的树枝文件,只显示 form-group 和 form-widget css 类 用于子元素而不是父元素。
肮脏的js脚本:
$('.form-group').each(function(e){
if($(this).parents('.form-group').length) {
var $realGroup = $(this).parents('.form-group');
$realGroup.toggleClass('form-group');
$realGroup.children('.form-widget').toggleClass('form-widget');
}
});
还有树枝位:
{% block form_row -%}
{% spaceless %}
<div class="form-group{% if (not compound or force_error|default(false)) and not valid %} has-error{% endif %}">
{{ form_label(form) }}
<div class="form-widget">
{{ form_widget(form) }}
{{ form_errors(form) }}
</div>
</div>
{% endspaceless %}
{%- endblock form_row %}
现在 twig 位是标准的 SF2 bootstrap 表单布局,我很确定我没有改变它。
因此,任何帮助摆脱 js 脚本并实际在 twig 中执行它的方法都会很棒,我尝试了一些方法,但每一个都比我用 js 所做的更糟糕,所以我有点卡。
编辑:
js 脚本所做的只是删除 css 类,因此布局有效。它看起来很平坦,因为它只是空的 div,但我所追求的并不是首先显示 div。我正在尝试更改 twig 脚本,而不是 css,因为这正是我们想要的方式。
你有三个选择。
1.Either 手动创建每个字段:
{{ form_start(form, {'action': path(''), 'attr': {'class':'productForm'}}) }}
{{ form_errors(form) }}
<div class="form-group">
{{ form_label(form.clientTitle, 'Client 1 title:', {'label_attr': {'class': 'control-label required'}}) }}
<div class="form-widget">
{{ form_widget(form.clientTitle, { 'attr': {'class': 'form-control' }}) }}
</div>
{{ form_errors(form.clientTitle) }}
</div>
<div class="form-group">
{{ form_label(form.firstName, 'Client 1 first name:', {'label_attr': {'class': 'control-label required'}}) }}
<div class="form-widget">
{{ form_widget(form.firstName, { 'attr': {'class': 'form-control' }}) }}
</div>
{{ form_errors(form.firstName) }}
</div>
<div class="form-group">
{{ form_label(form.firstName, 'Client 1 last name:', {'label_attr': {'class': 'control-label required'}}) }}
<div class="form-widget">
{{ form_widget(form.firstName, { 'attr': {'class': 'form-control' }}) }}
</div>
{{ form_errors(form.firstName) }}
</div>
<div class="form-group form-group-submit">
<div class="">
<a id="step2_save" class="has-spinner btn btn-default btn-submit">
<span class="spinner">
<i class="fa fa-spinner fa-spin"></i>
</span>
Complete the quote
</a>
</div>
</div>
{{ form_end(change_password) }}
2.Or 您可以创建自己的 form theme.
3.Or 为每个表单使用一个循环:
{% for child in form.children %}
<div class="form-group">
{{ form_label(child, null, {'label_attr': {'class': 'control-label required'}}) }}
<div class="form-widget">
{{ form_widget(child, { 'attr': {'class': 'form-control' }}) }}
</div>
{{ form_errors(child) }}
</div>
{% endfor %}
这完全取决于您未来的表单会有多少字段以及您有多少相似的表单。
但是,用 JS 做这种事情是不行的。
George Irimiciuc 已经帮助你了,我的意思是你可以使用 George answer 中提供的第二个选项,你需要关注表单主题的这一部分。
Symfony2 twig 根据所选主题创建表单,如果您尝试添加您的表单主题那么它会很好,其他选项意味着您只是将问题推到其他地方,这只是一个技巧。无需更新完整的表格,只需添加您的 form_row 即可,可以试试这个
http://symfony.com/doc/current/cookbook/form/form_customization.html#customizing-the-form-row
我用过这是我的项目,最好的一点是你可以从你的表单构建器发送属性哪些字段,然后检查 form_row 下的那些,这会呈现你的表单行并可以创建你想要的表单检查条件后 -
attr => array( 'parent_class' => false)
并且可以在 form_row 下查看
if( form.vars.attr.parent_class is defined )
并且可以在树枝中添加条件。
如果您遇到问题,例如您的表单有子表单和树枝 form_row 以奇怪的方式显示 -
我构建了这个项目,直到现在只有这个,因为有学生实体与各种实体相结合,所以在像个人资料这样的表单条目时。我同时使用了实体 Student 和 Address 我所做的是,我只是检查了这个
{% if ( not form.children ) or ( form.vars.expanded is defined and form.vars.expanded ) %}
<div class="{{ form.vars.attr['parent-div-class'] is defined ? form.vars.attr['parent-div-class'] : 'col-sm-12'}}">
<div class="form-group">
{{ form_label(form) }}
{{ form_widget(form) }}
{% if form_errors(form) %}
{{ form_errors(form) }}
{% endif %}
</div>
</div>
{% else %}
<div class="clear-both"></div>
{{ form_label(form) }}
{{ form_widget(form) }}
{% endif %}
代码并不完全像这样,但主要概念是。
希望你明白我的意思。
最简单的方法是创建自定义表单主题。
如果你看at the current Symfony2's bootstrap one,你可以看到:
{% block form_row -%}
<div class="form-group{% if (not compound or force_error|default(false)) and not valid %} has-error{% endif %}">
{{- form_label(form) -}}
{{- form_widget(form) -}}
{{- form_errors(form) -}}
</div>
{%- endblock form_row %}
"copound" 的东西实际上是告诉你当前元素是否包含 sub-elements (表单,集合,......基本上所有 parent 元素),如果你不想要 form-group
class parents,你只需要在自定义主题中重载这个块。
{# AppBundle::custom_theme.html.twig #}
{% use "bootstrap_3_layout.html.twig" %}
{% block form_row -%}
<div class="{% if not compound %}form-group{% endif %}{% if (not compound or force_error|default(false)) and not valid %} has-error{% endif %}">
{{- form_label(form) -}}
{{- form_widget(form) -}}
{{- form_errors(form) -}}
</div>
{%- endblock form_row %}
如果您根本不需要 div,请将其删除!现在就开始吧。
要在整个项目中应用更改,您可以在 config.yml
中添加:
twig:
# ...
form_themes:
- 'AppBundle::custom_theme.html.twig'
或仅在特定视图上使用它:
{% form_theme yourForm 'AppBundle::custom_theme.html.twig' %}
注意:yourForm
是您当前的状态 object。