如何将表单值(动态复选框,输入)动态插入数据库 这是我的查看文件:
<form action="<?php base_url('controller/insert'); ?>">
<table>
<thead>
<tr>
<th>Menu Id</th>
<th>Menu Name</th>
<th>Yes/No</th>
</tr>
</thead>
<tbody>
<?php foreach($result as $res) { ?>
<tr>
<td><input type="text" name="menu_id[]" value="<?= $res->menu_id ?>"></td>
<td><input type="text" name="menu_name[]" value="<?= $res->menu_name ?>"></td>
<td><input type="checkbox" name="yes[]" value="<?= $res->menu_id ?>"></td>
</tr>
<?php } ?>
</tbody>
</table>
</form>
这是我的控制器功能:
<?php
$fields = array(
'menu_id' => $this->input->post('menu_id'),
'menu_name' => $this->input->post('menu_name'),
'yes' =>$this->input->post('yes')
);
$this->db->insert('menu_table',$fields);
?>
当我打印此数组$ fields时,它显示为:
Array ( [0] => 2 [1] => 3 ) Array ( [0] => Plant [1] => Line ) Array ( [0] => on [1] => on ).
答案 0 :(得分:3)
您需要遍历数组。您可以将菜单ID用作键,因为它是顺序的,例如menu_id
的第一个与menu_name
的第一个相对应:
$menu_id = $this->input->post('menu_id');
$menu_name = $this->input->post('menu_name');
$yes = $this->input->post('yes');
$yes = is_null($yes) ? array() : array_flip($yes);
if (is_null($menu_id) || is_null($menu_name)) {
show_error('Parameters missing');
}
// should really be in a model
foreach ($menu_id as $key => $value) {
$data['menu_id'] = $value;
$data['menu_name'] = $menu_name[$key];
$data['yes'] = isset($yes[$value]) ? 'true' : 'false';
$this->db->insert('menu_table',$data);
}