我在这个多重选择的数组中花费了很多时间,它在多重下拉框中保存了几个值,我想要的是将选定的值插入到表中。
假设我1,2,3
从下拉框中被选中,当我 print_r($this->input->post('category'))` 时,它显示
Array ( [0] => 1 [1] => 2 [2] => 2 )
但是,当插入到表中时,它只有最后一个值被插入,而不是所有 3 个值。
这是选择几个值的视图:
$category = array(
'name' => 'category',
'id' => 'category'
);
<select name="category[]" id="<?php echo $category['id'] ?>" multiple="multiple">
<?php
foreach($catOpts as $catOpt)
{
$selected = ($this->input->post('category')==$catOpt->category_name) ? 'selected' : '';
echo '<option value="'.$catOpt->category_id.'" '.$selected.'>'.$catOpt->category_name.'</option>';
}
?>
</select>
在Controller中,我将值传递给验证,如果验证有效,则:
$this->form_validation->set_rules('category[]', 'Category', 'required');
if($this->form_validation->run()) { // validation ok
if(!is_null($data = $this->db_model->save_listing(
$this->form_validation->set_value('category[]')
))) { // success
//some message to acknowledge success created.
}
}
要插入表格的模型:
function save_listing($category)
{
$data = array(
'category_id' => $category
);
$this->db->insert('listing', $data);
return TRUE;
}
我不知道如何将所有值(数组)传递给控制器$this->form_validation->set_value('category[]')
,然后执行模型函数save_listing()
并将所有值保存到数据库中的列中。
请帮助解决我的问题,我浏览了很多论坛,但没有找到解决方案。
谢谢。