用javascript(codeigniter)动态表单将PHP导入数据库

Fat*_*hul 5 javascript php arrays codeigniter

我想使用数组插入多个数据(PHP CodeIgniter).但我仍然发现错误.错误是数组不清楚

function insert(){

    $hitung=count($_POST['pembicara']);

    $pengisi=implode(',',$_POST['pembicara']);
    $materi=implode(',',$_POST['materi']);
    $alasan=implode(',',$_POST['alasan']);

    $datapembicara = array(
    'id_kegiatan'   => $x,
    'nama_pembicara'   => $pengisi,                                         
    'materi'      => $materi,                                           
    'alasan'      => $alasan,
    );

    $this->m_admin_smf->add_pembicara($datapembicara);
}
Run Code Online (Sandbox Code Playgroud)

当我var_dump显示结果时

array (size=4)
  'id_kegiatan' => int 990550
  'nama_pembicara' => string '1,2' (length=9)
  'materi' => string '1,2' (length=3)
  'alasan' => string '1,2' (length=3)

array (size=4)
  'id_kegiatan' => int 990550
  'nama_pembicara' => string '1,2' (length=9)
  'materi' => string '1,2' (length=3)
  'alasan' => string '1,2' (length=3)
Run Code Online (Sandbox Code Playgroud)

结果应该是这样的

array (size=4)
  'id_kegiatan' => int 990550
  'nama_pembicara' => string '1' (length=9)
  'materi' => string '1' (length=3)
  'alasan' => string '1' (length=3)

array (size=4)
  'id_kegiatan' => int 990550
  'nama_pembicara' => string '2' (length=9)
  'materi' => string '2' (length=3)
  'alasan' => string '2' (length=3)
Run Code Online (Sandbox Code Playgroud)

我该怎么办?

怎么样这样?但是显示错误

$hitung = count($_POST['pembicara']);
$datapembicara = array();
for($i = 0; $i < $hitung; $i++) {
    $datapembicara[] = array(
        'id_kegiatan' => $x,
        'nama_pembicara' => $_POST['pembicara'][$i],
        'materi' => $_POST['materi'][$i],
        'alasan' => $_POST['alasan'][$i],
    );
}

$this->m_admin_smf->add_pembicara($datapembicara);
Run Code Online (Sandbox Code Playgroud)

Kev*_*vin 2

如果您希望将它们分成一系列批次,那么您将不得不执行其他操作,implode因为行为将与您需要的行为不同。您可以使用一个简单的for循环将此类数组结构创建为一系列批次:

// Controller
function insert()
{

    $hitung = count($_POST['pembicara']);
    $datapembicara = array();
    for($i = 0; $i < $hitung; $i++) {
        $datapembicara[] = array(
            'id_kegiatan' => $x,
            'nama_pembicara' => $_POST['pembicara'][$i],
            'materi' => $_POST['materi'][$i],
            'alasan' => $_POST['alasan'][$i],
        );
    }

    var_dump($datapembicara);

    $this->m_admin_smf->add_pembicara($datapembicara);
}
Run Code Online (Sandbox Code Playgroud)

旁注:我建议使用inputcodeigniter 类,因为它可以为您处理 XSS。

$value = $this->input->post('value', true); // add true parameter flag
Run Code Online (Sandbox Code Playgroud)

然后在创建该数组后,就可以使用->insert_batch()活动记录了。它会为您执行多次插入,此外,您的值会自动转义。

// Model
public function add_pembicara($data)
{
    $this->db->insert_batch($data);
}
Run Code Online (Sandbox Code Playgroud)