0

我有一个带有用于选择类别的下拉列表的编辑表单。我还制作了一个从数据库中获取类别的函数。

我为下拉列表设置了一个数组$opties以选择表单,并且一个名为此的“已选择”参数$selectie包含数据库中该特定公司的类别。

它看起来像这样:

<tr>
<td><?= form_label('Categorieen'); ?></td>
<td><?= form_dropdown('categorieen', $opties, $selectie); ?></td>
</tr>

问题

为什么我的“选定”部分不起作用?

当我这样做时,print_r($selectie)我得到:

Array
(
    [12] => Vlaggen
)

这是我在数据库中的类别。

当我这样做时,print_r($opties)我得到:

Array
(
    [11] => Webdesign
    [12] => Vlaggen
    [13] => Auto-s
    [14] => Electronica
    [15] => Boeken
    [16] => Antiek-en-Kunst
    [17] => Auto-Onderdelen
    [18] => Computers-Hardware
    [19] => Computers-Software
)

我不知道问题是什么。一些帮助将不胜感激。

控制器:

function updatebedrijven()
{
    $dbres = $this->db->get('categorieen');
    $ddmenu = array();
    foreach ($dbres->result_array() as $tablerow) {
        $ddmenu[$tablerow['idcategorieen']] = $tablerow['Categorie'];
    }
    $data['opties'] = $ddmenu;
    $id = $this->uri->segment(3); 
    $id2 = $this->uri->segment(3); 

    $data['selected'] = $this->members_model->getselection($id2);

    $data['info'] = $this->members_model->getbedrijf($id); 
    $data['id'] = $id;
    $this->load->view('members/header');
    $this->load->view('members/editform', $data);
    $this->load->view('members/footer');    
}

模型:

//This one is for the $opties

function getbedrijf($id) 
{ 
    $this->db->where('idbedrijven', $id); 
    $query = $this->db->get('bedrijven'); 

    if ($query->num_rows() == 1) { 
    $row = $query->row_array(0); 

    return $row; 
    } 
}

//This one is for the $selectie

function getselection($id2)
{
    $this->db->from('bedrijfcategorieen');
    $this->db->join('categorieen', 'bedrijfcategorieen.idcategorieen = categorieen.idcategorieen');
    $this->db->where('bedrijfcategorieen.idbedrijven', $id2);
    $query = $this->db->get();

    return $query->result();
}
4

1 回答 1

2

form_dropdown使用数组key => value作为它'value' and 'option',要从下拉列表中选择数据,您将需要所选数据的键,例如您选择

[12] => Vlaggen要选择它,您需要它的键12,而不是像这样的数组

Array
(
    [12] => Vlaggen
)

<? 
//just for testing
echo form_dropdown('categorieen', $opties, key($selectie)); 
?>
于 2013-05-29T14:42:56.680 回答