2015-08-29 68 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