我需要这方面的帮助,因为即使在阅读和检查了我在互联网上找到的所有资源之后,我也无法自己弄清楚。
我有一个图像实体。它有 3 个映射属性。
- ID
- 地点
- 拇指位置
我有自定义 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 %}
但是我真的很想使用这个令人惊叹的框架提供的良好实践......有时对我来说似乎并不像他们应该的那样明显。