1

我需要这方面的帮助,因为即使在阅读和检查了我在互联网上找到的所有资源之后,我也无法自己弄清楚。

我有一个图像实体。它有 3 个映射属性。

  1. ID
  2. 地点
  3. 拇指位置

我有自定义 ImageSelectType 表单类型,它扩展了 AbstractType:

buildForm函数如下所示:

public function buildForm(FormBuilderInterface $builder, array $options)
{
    $em = $options['em'];

    $qb = $em->createQueryBuilder();
    $result = $qb->select('i')
            ->from('BloggerBlogBundle:Image', 'i')
            ->leftJoin('i.articles', 'a')
            ->where('a is NULL')
            ;

    $builder
        ->add('images', 'entity', array(
                'class' => 'BloggerBlogBundle:Image',
                'query_builder' => $result,
                                    'required' => true,
                                    'multiple' => false,
                                    'expanded' => true,
            )
        )
                        ->setAttribute('widget', 'imageSelect')
        ;
}

因此,它会获取任何文章未使用的所有图像并用它们填充表单。使用这些选项,我得到单选按钮,如下所示:

<div id="image_images">
    <input type="radio" id="image_images_67" name="image[images]" required="required" value="67"><label for="image_images_67" class="required">c5252b4ffc9c50540218e25be1353b33aaa4ee05.png</label>
    <input type="radio" id="image_images_68" name="image[images]" required="required" value="68"><label for="image_images_68" class="required">fcfc7d7d05d63b1f55dff8cbff0bedeb3c917dfc.jpeg</label>
</div>

我现在想要的是所有单选按钮都具有自定义 html5 数据属性,该属性data-thumb="thumbnail/location.png"将是thumb_location该单选按钮表示的图像对象的属性值。

我希望我足够清楚。如果需要更多信息,我会提供。我已经阅读了很多关于此的内容,但我认为我想象的事情比实际情况更复杂。有一次我只想说'哦,算了,我将手动渲染它'并使用:

{% for choice in form.vars.choices %}
    <input type="radio" data-thumb="{{choice.thumb_location}}" />
{% endfor %}

但是我真的很想使用这个令人惊叹的框架提供的良好实践......有时对我来说似乎并不像他们应该的那样明显。

4

2 回答 2

0

不确定我是否理解这个问题,您想data-thumb直接在表单构建器中设置,对吗?

所以表单构建器包含主要功能(http://api.symfony.com/2.0/Symfony/Component/Form/FormBuilder.html),包括setAttribute(string $name, string $value)方法。

您可以执行以下操作:

setAttribute('data-thumb', $yourvalue);

要在输入字段中应用这些属性,您需要在 twig 模板中设置属性:

 <input type="radio" {{ block('widget_attributes') }} />
于 2012-12-23T00:00:33.920 回答
0

啊,我认为这与 FormType 一样与这个对象有关。所以在这种情况下,我看到了使用 buildView 方法设置变量的可能性。

 /**
 * {@inheritdoc}
 */
public function buildView(FormView $view, FormInterface $form, array $options)
{
     $view->vars['thumb'] = $options['thumb'];
}

您可以在 ->add(x, x, array('thumb_location' => 'location')) (或 setDefaultOptions 方法)中设置此选项。

但现在我不敢说实话。因为您需要像这样在视图中设置:

<input data-thumb="{{ thumb }}" type="radio" id="blog_article_image_17" name="blog_article[image]" required="required" value="17">

这意味着你<input data...再次手工制作。

不确定在您的情况下这是否可行,但我认为为无线电输入字段定义第二个 FormType 会很好:

public function buildForm(FormBuilderInterface $builder, array $options)
{
   ...this is your current form builder....

   ->add('radio', MyRadioType());
}
于 2012-12-25T17:14:43.050 回答