2015-08-29 95 views
-2

我使用的是一種形式,我有三個提交按鈕。編輯,刪除和重置但刪除和重置按鈕不起作用。三種提交按鈕的一種形式HTML和MySQL查詢

我做錯了什麼?

echo '<form action="" method="post"> 
    <input type="text" name="login" value="'.htmlspecialchars($object['login']).'" placeholder="Login" /><input type="text" name="password" value="'.htmlspecialchars($object['password']).'" placeholder="Password" /> 
     <input type="submit" value="Edit" /> 
     <input type="hidden" name="action" value="edit" /> 
     <input type="hidden" name="id" value="'.$object['id'].'" /> 
     <input type="submit" value="Delete" /> 
     <input type="hidden" name="action" value="dell" /> 
     <input type="submit" value="Reset" /> 
     <input type="hidden" name="action" value="res" /> 
</form>; 

在PHP中,它看起來像

if($_POST){ 
$action=(string)$_POST['action']; 
$id=(int)$_POST['id']; 
$name=(string)$_POST['name']; 

$name=trim($_POST['name']); 
$name=htmlspecialchars($name,ENT_QUOTES); 

    if($action=='add' && $name){ 
    mysql_query("INSERT INTO `stages` SET 
    `name`='".mysql_real_escape_string($name)."'"); 
    } else if($action=='edit' && $name){ 
    mysql_query("UPDATE `stages` SET 
    `name`='".mysql_real_escape_string($name)."' 
    WHERE `id`='".$id."' LIMIT 1"); 
    } else if($action=='edit'){ 
       mysql_query("DELETE FROM `stages` WHERE `id`='".$id."' LIMIT 1"); 
    mysql_query("DELETE FROM `questions` WHERE `stage_id`='".$id."'"); 
    } else if($action=='dell'){ 
    mysql_query("DELETE FROM `stages` WHERE `id`='".$id."' LIMIT 1"); 
    mysql_query("DELETE FROM `questions` WHERE `stage_id`='".$id."'"); 
    } else if($action=='reset'){ 
    mysql_query("UPDATE `stages` SET 
    `name`=NULL 
    WHERE `id`='".$id."' LIMIT 1"); 

    } 
} 
+1

首先閱讀http://stackoverflow.com/help/mcve –

+0

在表單中沒有名稱爲「name」的字段,因此它不會被POST。每個按鈕都是一個提交按鈕,因此在提交表單後,哪些字段實際上將由php腳本處理。 「名稱」的價值在哪裏? – RamRaider

回答

0

這可能是更加的那種你需要做這項工作的事情 - 雖然它是未經測試。

<?php 
echo ' 
<form id="actions" action="" method="post"> 
    <input type="text" name="login" value="'.htmlspecialchars($object['login']).'" placeholder="Login" /> 
    <input type="text" name="password" value="'.htmlspecialchars($object['password']).'" placeholder="Password" /> 

    <input type="button" value="Edit" data-action="edit" /> 
    <input type="button" value="Delete" data-action="dell" /> 
    <input type="button" value="Reset" data-action="res" /> 

    <input type="hidden" id="id" name="id" value="'.$object['id'].'" /> 
    <input type="hidden" id="action" name="action" /> 
</form> 

<script type="text/javascript"> 
    var col=document.getElementById("actions").querySelectorAll("input[type=\'button\']"); 
    if(col){ 
     for(var n in col)if(n && col[n] && col[n].nodeType==1) col[n].addEventListener(\'click\', function(e){ 
      document.getElementById("action").value=this.dataset.action; 
      this.parentNode.submit(); 
     }.bind(col[n]),false); 
    } 
</script>'; 


    if($_POST){ 
     $action=(string)$_POST['action']; 
     $id=(int)$_POST['id']; 
     $name=(string)$_POST['name']; 

     $name=trim($_POST['name']); 
     $name=htmlspecialchars($name,ENT_QUOTES); 

     if($action=='add' && $name){ 
      mysql_query("INSERT INTO `stages` SET `name`='".mysql_real_escape_string($name)."'"); 
     } else if($action=='edit' && $name){ 
      mysql_query("UPDATE `stages` SET `name`='".mysql_real_escape_string($name)."' WHERE `id`='".$id."' LIMIT 1"); 
     } else if($action=='edit'){ 
      mysql_query("DELETE FROM `stages` WHERE `id`='".$id."' LIMIT 1"); 
      mysql_query("DELETE FROM `questions` WHERE `stage_id`='".$id."'"); 
     } else if($action=='dell'){ 
      mysql_query("DELETE FROM `stages` WHERE `id`='".$id."' LIMIT 1"); 
      mysql_query("DELETE FROM `questions` WHERE `stage_id`='".$id."'"); 
     } else if($action=='reset'){ 
      mysql_query("UPDATE `stages` SET `name`=NULL WHERE `id`='".$id."' LIMIT 1"); 
     } 
    } 

?> 

這些按鈕將調用JavaScript函數,然後用適當的操作和其他參數提交表單。

+0

不幸的是按鈕不起作用 – Valentina

+0

您是否在控制檯中發現任何錯誤,因爲我現在已經測試並按預期提交了表單? – RamRaider

+0

我建議你創建sql語句作爲每個動作的變量,並在表單提交後將它們回顯出來,以便您可以看到sql的外觀。編輯它們,如果他們看起來錯了,一旦確定實際調用mysql_query函數。此外,您可以省略刪除語句中的「限制1」語句 – RamRaider