我正在尝试在表单中创建实体字段类型。这是代码:
$extraSpecsRepository = $this -> getDoctrine()
-> getRepository('LabsCatalogBundle:Specs');
$availQuery = $extraSpecsRepository->createQueryBuilder('sel')
->where("sel.cat = '0'")
->getQuery();
$available = $availQuery->getResult();
$extraSpecsRepository = $this -> getDoctrine()
-> getRepository('LabsCatalogBundle:ProductExtraspecs');
$selQuery = $extraSpecsRepository->createQueryBuilder('sel')
->join('sel.specs', 'specs')
->where("specs.cat = '0' AND sel.regmatid = $id")
->getQuery();
$selected = $selQuery->getResult();
$form = $this ->createFormBuilder($product)
->add('extraspecs', 'entity', array(
'class' => 'LabsCatalogBundle:Specs',
'choices' => $typeavailable,
'data' => $selected,
'property' => 'specid',
'multiple' => false,
))
->getForm();
这是来自var_dump
和$selected
变量的$typeavailable
:
$typeavailable:
array (size=4)
0 =>
array (size=4)
'specid' => int 20
'desc' => string 'Primary Antibodies' (length=18)
'cat' => int 0
'type' => int 1
1 =>
array (size=4)
'specid' => int 21
'desc' => string 'Secondary Antibodies' (length=20)
'cat' => int 0
'type' => int 2
2 =>
array (size=4)
'specid' => int 22
'desc' => string 'Fluorescent-Labeled Antibodies' (length=30)
'cat' => int 0
'type' => int 5
3 => &
array (size=4)
'specid' => int 27
'desc' => string 'Related Antibodies' (length=18)
'cat' => int 0
'type' => int 7
$selected:
array (size=1)
0 => &
array (size=4)
'regmatid' => int 1600
'specid' => int 21
'attrib' => null
'value' => null
你知道有什么不对吗?
因为它正在生成下拉列表但不选择“选定”值。
答案 0 :(得分:1)
赋予'choices'
索引($typeavailable
)的对象应与赋予'data'
的SINGLE对象属于同一类。目前你正在回赠array
持有错误的物品。为什么单个物体?因为您的表单仅支持1个选定项目('multiple' => false,
)。
使用此方法解决问题:
$result = $selQuery->getSingleResult()->getSpecs();
$selected = $result[0];
这段代码应该为您提供您想要选择的Specs对象。
如果您的选择查询也返回多于1个对象,您可能想要在您的关系或查询中重做某些内容。如果您不想这样做,您仍然可以使用以下内容:
$results = $selQuery->getResult();
$result = $results[0]->getSpecs();
$selected = $result[0];