2012-08-31 124 views
13

我想要做一个简单的表单来添加一个名称和颜色的活动。symfony2自定义表单选择选项

所以我想打一个清单,色彩的一些数组,现在它正在我有颜色的名称。
我可以将任何属性添加到我的选择标签:

$form = $this->createFormBuilder($myclass) 
->add('Colors','choice',array('label'=>'select some colors', 
      'multiple'=>true, 
      'choices'=>array(1=>'red', 2=>'blue', 3=>'green'), 
      'attr'=>array('style'=>'width:300px', 'customattr'=>'customdata') 
      )); 

输出将是这样的:

<select name="select" style="width: 300px;" multiple="multiple" customattr="customdata"> 
    <option value="1">red</option> 
    <option value="2">blue</option> 
    <option value="3">green</option> 
</select> 

但我怎么可以添加selected="selected"和我选择的选择我想要的任何属性?像这样:

<select name="select" style="width: 300px;" multiple="multiple" customattr="customdata"> 
    <option style="background-color: #F00;" value="1" selected="selected">red</option> 
    <option style="background-color: #00F;" value="2" selected="selected">blue</option> 
    <option style="background-color: #0F0;" value="3">green</option> 
</select> 

我的问题是:我怎么可以添加自定义ATTR为option标签(不适用于select标签)由symfony的FormBuilder。
通知:我不想使用JavaScript。我想使用symfony2 FormBuilder来自定义我的选择选项。

回答

10

通常,字段的默认数据由存储在您的对象中的值决定。例如,如果

class MyClass 
{ 
    private $Colors = array(1, 2); 
} 

则条目“1”和“2”(有标签“红色”和“绿色”)默认为选择将被显示。

$myObject->Colors = array(1, 2); 

$form = $this->createFormBuilder($myObject) 
    ... 

最后一种可能性是通过将“数据”选项来覆盖存储在对象的默认值:

$builder->add('Colors', 'choice', array(
    'label' => 'select some colors', 
    'multiple' => true, 
    'choices' => array(1 => 'red', 2 => 'blue', 3 => 'green'), 
    'attr' => array('style' => 'width:300px', 'customattr' => 'customdata'), 
    'data' => array(1, 2), 
)); 
1

symfony中的每个Field都继承自abstract field type,它有一个data选项,您可以在其中传递默认选项。

顺便说一句,不传style东西,定制ATTRS使用data-*属性。

+0

我如何使用'数据'属性?我如何将它传递给FormBuilder。请详细解释。 –

+0

只需将'customattr'重命名为'data-customattr',即可符合HTML标准。 – moonwave99

+0

我想为''option'标签使用'customattr',而不是'select'标签。我怎样才能通过FormBuilder做到这一点? –

3
你也可以在对象该值将它传递给表单之前存储

使用如本文所述选择的FO =“选择”数据选项: http://symfony.com/doc/current/reference/forms/types/field.html

在乌尔情况下可能是这样

$form = $this->createFormBuilder($myclass) 
->add('Colors','choice',array('label'=>'select some colors', 
      'multiple'=>true, 
      'choices'=>array(1=>'red', 2=>'blue', 3=>'green'), 
      'attr'=>array('style'=>'width:300px', 'customattr'=>'customdata'), 
      'data'=> 1 
      )); 

新元件是数据设置的选择阵列的数量作为选择的属性

1

中添加类方法的Symfony \分量\表格\ AbstractType :: finishView

public function finishView(FormView $view, FormInterface $form, array $options) 
{ 
    parent::finishView($view, $form, $options); 

    $additionalAttributes = array(); 

    // myMethod - method $choice, returns a value that is to be substituted into the attribute 
    foreach ($view->children['orders']->vars['choices'] as $id => $choice) { 
     $additionalAttributes[$id] = array(
      'data-cost' => $this->propertyAccessor->getValue($choice->data, 'myMethod'), 
      'disabled' => 'disabled', 
     ); 
    } 

    foreach ($view->children['orders']->children as $id => $child) { 
     $child->vars['attr'] = array_replace(
      isset($child->vars['attr']) ? $child->vars['attr'] : array(), 
      $additionalAttributes[$id] 
     ); 
    } 
} 

Symfony2 Form – add attribute tag option in select field type

1

为了添加根据选择的值,选择自定义属性,考虑使用ChoiceType字段的choice_attr选项。

例如,如果你想JSON编码实体传递给选项,你可以使用这样的事情:

'choice_attr' => function($val, $key) { 
    return ['data-object' => json_encode($val)]; 
},