3

我正在尝试在表单中创建实体字段类型。这是代码:

$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_dumpfrom both$selected$typeavailablevariables`:

$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

你看有什么不对吗?因为它正在生成下拉列表但没有选择“选定”值。

4

1 回答 1

1

提供给'choices'index( $typeavailable) 的对象应该与提供给 的 SINGLE 对象属于同一类'data'。目前,您正在回馈array持有错误的对象。为什么是单个对象?因为您的表单仅支持 1 个选定项目 ( 'multiple' => false,)。

使用它来解决问题:

$result = $selQuery->getSingleResult()->getSpecs();
$selected = $result[0];

这段代码应该给你想要选择的 Specs 对象。

如果您的选择查询还返回超过 1 个对象,您可能希望在您的关系或查询中重做一些事情。如果您不想这样做,您仍然可以使用以下内容:

$results = $selQuery->getResult();
$result = $results[0]->getSpecs();
$selected = $result[0];
于 2012-11-12T16:29:33.580 回答