2012-07-06 141 views
1

我是PHP新手。所以我先道歉,如果我使用愚蠢的策略。我正在PHP网站上工作。 我的页面从MySql中查询数据,并在我的复选框中显示在html表格中。用户可以使用复选框和按钮删除任何数据。这一切都是使用JavaScript完成的。这里是我的代码上点击保存按钮的MySQL更新查询的时间,以保存页面所做的所有更改从HTML表格在php中获取HTML表格数据

<script type="text/javascript"> 
function deleteRow() { 
     try { 
      var table = document.getElementById("Categories"); 
     var rowCount = table.rows.length; 



     for(var i=0; i<rowCount; i++) { 
      var row = table.rows[i]; 
      var chkbox = row.cells[0].childNodes[0]; 
      if(null != chkbox && true == chkbox.checked) { 
       table.deleteRow(i); 
       rowCount--; 
       i--; 
      } 


     } 
     }catch(e) { 
      alert(e); 
     } 
    } 

</script> 

删除数据。 我知道这可以通过PHP完成。但这里的问题是如何我可以从PHP中的数据从PHP运行查询? 如果有人能指出我正确的方向,我会感谢你。

谢谢。

+0

如何使用DOM?看看这篇关于HTML DOM的教程:http://www.w3schools.com/htmldom/default.asp – pheromix 2012-07-06 11:19:52

+0

你的意思是你想发送当前DOM--即HTML页面的当前活动状态 - 作为一个字符串到你的PHP脚本? – Utkanos 2012-07-06 11:21:59

+0

@utkanos是的,我试图这样做。想发送我的页面的当前活状态html。 – 2012-07-06 11:23:25

回答

2

你可以制作一个表格,你会有复选框,如:<input type="checkbox" name="m_Name[]" value="id_of_element">。当您在服务器端提交此表,你可以这样做:

foreach ($_POST['m_Name'] as $id){ 
    $query = 'DELETE FROM table WHERE id='.$id; 
    //execute query with mysqli_*, PDO or mysql_*; NOTE: if you are not doing educational project don't use last one. 
} 

但更好的方法是:

$query = 'DELETE FROM table WHERE id IN ('; 
$in = ''; 

foreach ($_POST['m_Name'] as $id) 
    $in .= $id.','; 

$in = substr($in, 0, strlen($in)-1).')'; // removes extra "," at the end. 
$query .= $in; 
//run the query. 

最后一个西港岛线只执行一个查询,删除记录,以便它获得更好的性能。但是,我创建查询的方式对我来说似乎很难看,但我对有关改进的事情感到厌倦。 :)

+1

可能想要清理你的ID输入...使用intval应该有所帮助。 – 2012-07-06 11:52:00

+0

@ $ _POST'中的@BrianAdkins被视为字符串,并将它们与查询字符串连接起来。为什么我需要使用'intval'?如果我使用准备好的语句并将这些值作为整数绑定,那么您会是对的,但为此目的,它将是额外的IMO。 – Leri 2012-07-06 11:57:31

+0

您的示例代码当前容易受到SQL注入的攻击...例如,某人提交了一个ID设置为单引号而不是数字的POST。 – 2012-07-06 12:02:35