插入具有相同文本字段值的多个复选框值(代码点火器)


Inserting multiple checkbox values with a same text field value (codeigniter)

我正试图将值放入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>&nbsp;</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