我尝试使用codeigniter进行在线测验,其中包含一些主题的动态测验。用户可以在每个问题中添加问题和多项选择答案。如何在每个问题的每个多项选择答案中得到每个答案的价值?
<?php echo form_open_multipart('c_kuis/addKuisAnswer'); ?>
<?php foreach($soalKuis as $row){?>
<?php $jawab_array = array($row->pil_a,$row->pil_b,$row->pil_c,$row->pil_d);
?>
<p><?=$row->soal?></p>
<input type="radio" name="jawaban<?=$row->id_soal?>" value="A">A.<?=$jawab_array[0]?></input><br>
<input type="radio" name="jawaban<?=$row->id_soal?>" value="B">B.<?=$jawab_array[1]?></input><br>
<input type="radio" name="jawaban<?=$row->id_soal?>" value="C">C.<?=$jawab_array[2]?></input><br>
<input type="radio" name="jawaban<?=$row->id_soal?>" value="D">D.<?=$jawab_array[3]?></input><br>
<input type="hidden" name="id_soal_kuis" value="<?=$row->id_soal?>"></input>
<br><br>
<?php } ?>
<button class="btn btn-primary" type="submit">Submit</button>
<?php form_close(); ?>
这是我尝试检查时的代码:
<input type="radio" name="jawaban1" value="A">A.Hamster</input><br>
<input type="radio" name="jawaban1" value="B">B.Tiger</input><br>
<input type="radio" name="jawaban1" value="C">C.Shark</input><br>
<input type="radio" name="jawaban1" value="D">D.Lion</input><br>
<br><br>
<input type="radio" name="jawaban2" value="A">A.was</input><br>
<input type="radio" name="jawaban2" value="B">B.have</input><br>
<input type="radio" name="jawaban2" value="C">C.am</input><br>
<input type="radio" name="jawaban2" value="D">D.is</input><br>
<br><br>
<button class="btn btn-primary" type="submit">Submit</button>
这是我的控制器看起来像:
public function addKuisAnswer(){
if($this->session->userdata('data_user')->level != 1){
redirect('/c_user/login');
}
$id_soal_kuis = $_POST['id_soal_kuis'];
$id_user = $this->session->userdata('data_user')->id_user;
$answer = $_POST['jawaban']; //The Problem's here... I should put jawaban with id_soal. Because the answer named 'jawaban1','jawaban2' etc it will follow the id_soal. How can i insert it?
$this->load->model('m_kuis');
$this->m_kuis->createAnswerKuis($id_soal_kuis, $id_user, $answer);
echo " <script>
alert('Jawaban Tugas Tersimpan!');
history.go(-2);
</script>";
}
这是我的模特:
public function createAnswerKuis($id_soal_kuis, $id_user, $answer){
$data = array(
'id_soal_kuis'=>$id_soal_kuis,
'id_user' => $id_user,
'jawaban_kuis' => $answer
);
$this->db->set('tgl_jawab', 'NOW()', FALSE);
$this->db->insert('jawab_kuis', $data);
}
我希望表格如下:This is the picture of database table i made.I want to insert the data like this.
问题出在Controller中。我的Controller如何在数据库中发布单选按钮name="jawaban<?=$row->id_soal?>"
的值?
答案 0 :(得分:1)
我希望这个小小的改变会帮助你
public function addKuisAnswer(){
if($this->session->userdata('data_user')->level != 1){
redirect('/c_user/login');
}
$id_soal_kuis = $_POST['id_soal_kuis'];
$id_user = $this->session->userdata('data_user')->id_user;
$this->load->model('m_kuis');
$i=1;
while(isset($_POST['jawaban'.$i]))
{
$answer = $_POST['jawaban'.$i];
// var_dump($answer);
$this->m_kuis->createAnswerKuis($id_soal_kuis, $id_user, $answer);
$i++;
}
echo " <script>
alert('Jawaban Tugas Tersimpan!');
history.go(-2);
</script>";
}
您可以按顺序更改单选按钮名称(因为单选按钮中不需要附加ID)
<?php
$i=1;
foreach($soalKuis as $row){?>
<?php $jawab_array = array($row->pil_a,$row->pil_b,$row->pil_c,$row->pil_d);
?>
<p><?=$row->soal?>
<input type="hidden" value=<?php echo $row->id_soal?> name='id_soal'<?= $i ?>/></p>
<input type="radio" name="jawaban<?=$i?>" value="A">A.<?=$jawab_array[0]?></input><br>
<input type="radio" name="jawaban<?=$i?>" value="B">B.<?=$jawab_array[1]?></input><br>
<input type="radio" name="jawaban<?=$i?>" value="C">C.<?=$jawab_array[2]?></input><br>
<input type="radio" name="jawaban<?=$i?>" value="D">D.<?=$jawab_array[3]?></input><br>
<input type="hidden" name="id_soal_kuis" value="<?=$row->id_soal?>"></input>
<br><br>
<?php $i++;} ?>
答案 1 :(得分:0)
这是你的意思:
如何在数据库中插入单选按钮名称=&#34; jawabanid_soal?&gt;&#34;的值?
或者,如何读取所选单选按钮的值,然后将其插入数据库?
我会回答这两个问题。要阅读答案的值,您可以使用foreach
循环:
<?php
$egabat= array();
foreach($soalKuis as $row){
$egabat[$row->id_soal]= $_POST["jawaban".$row->id_soal];
} ?>
要在DB中插入值,如果这是MySql,那么我推荐这个非常有用的指南。
答案 2 :(得分:0)
function insert($postdata) //modelfunction for insert
{
$array(
$tablevalues=
'filed1'=>$_POST["jawaban".$row->id_soal], // consider field1 as ur table field
);
$this->db->insert('table_name',$tablevalues);
}
答案 3 :(得分:0)
在提交表单时,您可以使用名称数组字段隐藏 $ row-&gt; id_soal 的值,然后获取带有来自隐藏字段的动态ID的单选按钮的值。
<?php
$egabat= array();
foreach($_POST['hiddenfield'] as $idsoal){
$egabat[$idsoal]= $_POST["jawaban".$idsoal];
} ?>
答案 4 :(得分:0)
以下是实现这一目标的方法:
preg_match_all
并且在控制器中,您将在数组中包含这些值,可以像:
一样进行检索$matches