使用html&存储表单数据PHP

时间:2011-11-21 09:52:56

标签: php html forms

我有一个包含50个问题的表格。在用户填写表单后,我想将他们带到另一个页面,首先取消/确认他们已完成表单。我的问题是,如果他们选择取消,我该如何放回表格中已回答的所有字段?

EDITED

我编辑了我的问题以显示我的代码,因为我很喜欢:

$sql1="SELECT * FROM ex_question WHERE test_name = '$tid' ORDER BY RAND()";
$result1=mysql_query($sql1);
echo "<form method='post' action='....'>";
while($row1 = mysql_fetch_array($result1))
{
    $test_name=$row1['test_name'];
    $q_nr=$row1['q_nr'];
    $q_type=$row1['q_type'];
    $question=$row1['question'];
    $option1=$row1['option1'];
    $option2=$row1['option2'];
    $option3=$row1['option3'];

echo "$question";

if ($q_type != 'mr') {
if($option1!="") {
echo "<input type='radio' name='question[$q_nr]' value='A'>$option1<BR>";
} else {
echo ''; }

if($option2!="") {
echo "<input type='radio' name='question[$q_nr]' value='B'>$option2<BR>";
} else {
echo ''; }

if($option3!="") {
echo "<input type='radio' name='question[$q_nr]' value='C'>$option3<BR>";
} else {
echo ''; }

} else { // else if not <> mr

if($option1!="") {
echo "<input type='checkbox' name='question[$q_nr][]' value='A'>$option1<BR>";
} else {
echo ''; } 
if($option2!="") {
echo "<input type='checkbox' name='question[$q_nr][]' value='B'>$option2<BR>";
} else {
echo ''; } 
if($option3!="") {
echo "<input type='checkbox' name='question[$q_nr][]' value='C'>$option3<BR>";
} else {
echo ''; } 
} //end else if q_type <> mr
echo "<BR>";
echo "<BR>";
echo "</p>";
} //end while row1
echo "<input type='submit' value='Finish'>";
echo "</form>";

4 个答案:

答案 0 :(得分:1)

$_POST$_GET数组传递到确认页面,如果它们点击取消,则将数组传回页面,然后填写元素。

答案 1 :(得分:1)

将“取消”按钮设为“提交”,然后将其发回原始问卷。在那里,你可以这样做:

<input type="text" name="q1" value="<?=isset($_POST['q1']) ? $_POST['q1'] : '';?>" />

或者:

<input type="radio" name="q2" value="A" <?=isset($_POST['q2']) && $_POST['q2'] == 'A' ? 'checked="checked"' : '';?>" />
<input type="radio" name="q2" value="B" <?=isset($_POST['q2']) && $_POST['q2'] == 'B' ? 'checked="checked"' : '';?>" />

同样适用于option内的select元素(已选择=“已选择”)。

答案 2 :(得分:1)

最简单的解决方案是添加:

<INPUT type=button value="Cancel" onClick="history.back();">

当你回去时,表格仍然存在。

答案 3 :(得分:0)

您只需在表格的标记中使用$_REQUEST['Answer']即可。