0

我正在制作一个关于在线考试的项目,管理员可以在其中添加测试,然后它将在 div 中显示。在 div 内,它将显示所有选定测试的列表,因此,他可以通过简单地单击十字符号来删除任何测试。因此,我陷入了一个过程,如果我要删除任何测试,然后我提交表单,那么它会向我显示所有测试,包括已删除的测试。以下是我的代码:

<?php  
    if(isset($_POST['addTest']))
    {  
        echo "<br>";
        echo "SELECTED TEST LIST";
        echo "<br>";
        echo '<div style="backfround:white;padding:5px;border:2px solid;overflow:scroll;height:100px;">';
        $fruitList = implode(', ', $_POST['jdb']);
        $jdStore = explode(',',$fruitList);
        $jdValueStore = ""; 

        for($i=0;$i<count($jdStore);$i++)
        {
            $testShowState = "select testId, testName from test where testId= '$jdStore[$i]'";
            $testShowQuery = mysql_query($testShowState);
            $testShowFetch = mysql_fetch_array($testShowQuery);

            echo  $jdValueStore[] =  "<div class='divClass'>

                                          <p>".$testShowFetch['testName']."</p>
                                          <img src='images/deletebttn.gif' alt='delete' class='deleteDiv' />
                                      </div>";
        }

        echo '</div>';
    } 

    $jdTotal = serialize($jdValueStore);
    $encoded = htmlentities($jdTotal);

?>
<input type="hidden" name="jdStoreValue" value="<?php echo $encoded; ?>">
<input type="submit" class="button add" value="Save" style="width:auto;" id="addSave" onclick="myAddSave()" name="myAddSave" >

在我获取值的页面上:

$jdStoreValue = unserialize($_POST['jdStoreValue']);

for($i=0;$i<count($jdStoreValue);$i++)
{
    echo $jdStoreValue[$i];
}

它向我展示了所有的测试。我不想要删除的测试。

4

2 回答 2

0

您应该删除序列化代码。

if(isset($_POST['addTest']))
{  
    echo "<br>";
    echo "SELECTED TEST LIST";
    echo "<br>";
    echo '<div style="backfround:white;padding:5px;border:2px solid;overflow:scroll;height:100px;">';
        $fruitList = implode(', ', $_POST['jdb']);
        $jdStore = explode(',',$fruitList);
        $jdValueStore = ""; 

        for($i=0;$i<count($jdStore);$i++)
        {      
            $testShowState = "select testId, testName from test where testId= '$jdStore[$i]'";
            $testShowQuery = mysql_query($testShowState);
            $testShowFetch = mysql_fetch_array($testShowQuery);
            echo '<input type="hidden" name="fruitList[]" value="'.$testShowFetch['testId'].'" />';
            echo  $jdValueStore[] =  "<div class='divClass'>

                <p>".$testShowFetch['testName']."</p>
                    <img src='images/deletebttn.gif' alt='delete' class='deleteDiv' />
                </div>";
         }

        echo '</div>';
} 
<input type="submit" class="button add" value="Save" style="width:auto;" id="addSave" onclick="myAddSave()" name="myAddSave" >
于 2013-04-30T06:49:18.807 回答
0

将 jquery onclick 事件绑定到交叉按钮,这将减少删除时的检查次数,同时更新隐藏字段。

于 2013-04-30T06:54:49.483 回答