我正试图将值放入MySQL表中,如下所示:
|---sbjct_name---|---级别---|
|----------物理---------------|----1级-----|
|----------物理---------------|----2级-----|
|----------物理---------------|----3级-----|
|----------微积分--------|----1级-----|
|----------微积分--------|----2级-----|
(我不知道如何制作桌子,但我想你已经明白了)
假设我要将"Math"与"Level 1"、"Level 2"answers"Level 3"值一起放入sbjct_name列中。
基本思想来自这个图(为相同的输入文本值选择值)。
不是为每个级别多次插入"数学",我正试图让它一次性提交复选框标记。它将类似于这张图片(带复选框)。
我不知道如何实现这一点(或者在CI中是否可能)。
这是我的控制器的一些代码
public function add_subject()
{
$data = array();
if ($this->input->post('savebttn'))
{
$this->form_validation->set_rules('sbjct_name', 'Subject Name', 'trim|required|xss_clean');
$this->form_validation->set_rules('level', 'Level', '|required|is_natural');
$this->form_validation->set_error_delimiters('<span class="fielderror">','</span>');
if ($this->form_validation->run() == FALSE)
{
$data['reset'] = FALSE;
}
else
{
//I don't know what to do here
//I don't know what to do here
//I don't know what to do here
//I don't know what to do here
}
}
$data['level'] = $this->admin_model->get_checkbox_option('level', 'lvl_id', 'lvl_name');
$data['page'] = 'createsubject';
$this->load->view('admin/main', $data);
}
这是模型中的复选框视图功能,
public function get_checkbox_option($table, $id, $name, $selected=0)
{
$query = $this->db->get($table);
$select= '';
if ($query->num_rows() > 0)
{
foreach ($query->result_array() as $row)
{
$selected_option = ($selected == $row[$id]) ? 'selected = "selected" ':' ';
$select .='<input type="checkbox" name="level" value="'.$row[$id].'" '.$selected_option.'>'.$row[$name].'<br>';
}
}
return $select;
}
这是视图上的表单,
<form action="" method="post" id="createcategoryform">
<table>
<tbody>
<tr>
<td><div class="label">Subject Name</div></td>
<td><div class="input">
<input type="text" name="sbjct_name" size="39" class="ui-corner-all input-text validate[required]">
<?=form_error('sbjct_name');?>
</div></td>
</tr>
<tr>
<td><div class="label">Level</div></td>
<td><div class="input-text ui-corner-all validate[required]">
<?=(isset($level)) ? $level: '';?>
</div><?=form_error('level');?></td>
</tr>
<tr>
<td> </td>
<td><input type="submit" value="Save" name="savebttn" class="input-button ui-corner-all ui-state-default"></td>
</tr>
</tbody>
</table>
</form>
如果你能提供任何线索,我将不胜感激D
第一个
把你的复选框做成一个数组,使它看起来像这个
$select .='<input type="checkbox" name="level[]" value="'.$row[$id].'" '.$selected_option.'>'.$row[$name].'<br>';
注意这个名字。你的name="level"
和我的name="level[]"
,然后您可以将所有级别作为一个变量
秒
让你的控制器像这个
if ($this->form_validation->run() == FALSE)
{
$data['reset'] = FALSE;
}
else
{
// make array container for input batch
$insertData = array();
if(!empty($this->input->post('level'))) {
foreach($this->input->post('level') as $level) {
$tempArray = array(
'sbjct_name' => $this->input->post('sbjct_name'),
'level' => $level
);
array_push($insertData, $tempArray);
}
// it's better to put this in model
// but for example purpose I put it there
$this->db->insert_batch('table', $insertData);
//do what you want to do here
}
}
希望你能理解@nasamikhail