3

わかりましたので、2 つのオプションを含む選択フォームがあります

$builder->add('type', 'choice', array(
    'label' => 'User type',
    'choices' => array('1' => 'Customer', '2' => 'Supplier'),
    'expanded' => true,
    'multiple' => false,
    'required' => false,
));

そして、小枝を使用してビュー内のオプションを分割し、次のようなものを取得したいと考えています:

{{ form_widget(form.type/choice_1/) }}
some html stuf
{{ form_widget(form.type/choice_2/) }}

何か提案はありますか?

4

2 に答える 2

9

フォームにテンプレートを追加する必要があります。ドキュメントは次のとおりです: http ://symfony.com/doc/current/cookbook/form/form_customization.html

ここに複数の例があります: https ://github.com/phiamo/MopaBootstrapBundle/blob/master/Resources/views/Form/fields.html.twig

このフィールドはあなたのためです:

{% block choice_widget_expanded %}
{% spaceless %}
<div {{ block('widget_container_attributes') }}>
{% for child in form %}
    <label class="{{ (multiple ? 'checkbox' : 'radio') ~ (widget_type ? ' ' ~ widget_type : '') ~ (inline is defined and inline ? ' inline' : '') }}">
        {{ form_widget(child, {'attr': {'class': attr.widget_class|default('')}}) }}
        {{ child.vars.label|trans({}, translation_domain) }}
    </label>
{% endfor %}
</div>
{% endspaceless %}
{% endblock choice_widget_expanded %}

あなたはあなたが望むことは何でもすることができます:放っておいてください{{ form_widget(child, {'attr': {'class': attr.widget_class|default('')}}) }}:)

  1. ファイルを作成する必要がありますYourBundle/Resources/Form/fields.html.twig
  2. 上記のコードをそこに貼り付けます。
  3. フォームにテーマを追加します。{% form_theme form 'AcmeDemoBundle:Form:fields.html.twig' %}
  4. そして、ロックンロールの準備をしてください!
于 2012-09-20T07:43:58.353 に答える
2

定義されたフィールド数:

{{ form_widget(form.type.0) }}{{ form_label(form.type.0) }}
    some html stuf
{{ form_widget(form.type.1) }}{{ form_label(form.type.0) }}

可変数のフィールド:

{% for i in 0..form.type|length-1 %}
    {{ form_widget(form.type[i]) }}
    {{ form_label(form.type[i]) }}
{% endfor %}

そして、順番にない id を選択した場合:

例えば

$typeChoice = [
    "choice 1" => 2,
    "choice 2" => 5
]

{% for type in form.type %}
    {{ form_label(type) }}
    {{ form_widget(type) }}
{% endfor %}
于 2015-10-09T11:29:41.330 に答える