Concrete5通过DB的数组通过形式助手创建选择框



我正在尝试使用助手的构建框,并在单个页面上使用db的数组。我在单页控制器中使用了:

$comp = $db->getAll('SELECT id, name FROM table', array());
$this->set('companies', $comp);

和单页:

$cmp = array();
foreach($companies as $company){
$cmp[] = "'".$company['id']."' => '".$company['name']."'";
}; 
$cmp = implode(", ", $cmp); 
echo $form->select('companyID', array($cmp), '1');

的结果是: <select id="companyID" name="companyID" ccm-passed-value="1" class="form-control" pmbx_context="B49783CE-698A-47B4-8895-3D930C747D42"><option value="0">'1' =&gt; 'Bucuc', '2' =&gt; 'Neocrest'</option></select>

我的意思是每个数组而不是新选项,它给我一个值,并立即超过整个数组。我想得到: <select id="companyID" name="companyID" > <option value="1">Bucuc</option> <option value="2">Neocrest</option> </select>

任何人都可以指向问题在哪里?顺便说一句,我正在处理混凝土5.7.5.8安装。谢谢,xaba

已解决。创建了2个数组,一个用于键,一个用于值,然后将它们组合在一起。这是最终代码:

$key = array();
$value = array();
foreach($companies as $company){
    $key[] = $company['id'];         
    $value[] = $company['name'];
}; 
$c = array_combine($key, $value);
echo $form->select('companyID', $c, '1');

最新更新