我正在尝试创建一个标记系统,例如堆栈溢出。所以每个标签旁边都有一个小x,这样当用户删除它时,它就会从数据库中动态删除。只有输入标签的用户才能删除它们。我正在使用 x 的锚标记并使用 Ajax 将请求发送到 php 脚本,该脚本将删除元素,如下所示:
<?php
require_once("database_connection_handler.php");
$x=$post->ID;
$i=0;
$select_query = "Select * from wp_tags inner join wp_posts_tags on wp_posts_tags.tag_id=wp_tags.id where wp_posts_tags.post_id='". $x . "'";
$result = mysql_query($select_query);
$num=mysql_num_rows($result);
echo "</ul>";
echoTagHTML();
while ($i < $num) {
$tag=mysql_result($result,$i,"tag");
$id=mysql_result($result,$i,"id");
echo "<li>";
tagLinks($tag,$id);
if(is_current_user())
{
echo "<a href='javascript:void(0)' onclick='deleteTag($id);'>  x</a>";
}
echo "</li>";
$i++;
}echo "</ul></div>";
?>
处理这个问题的 Ajax 代码是:
function deleteTag(str){
if (str.length != 0){
if (window.XMLHttpRequest){// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();}
else{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");}
xmlhttp.open("GET","links/livesearch.php?del="+str,true);
xmlhttp.send();
}
else{return;}
}
php脚本是:
<?php
$del=$_GET["del"];
ConnectToDB();
$delete_query="delete from wp_tags where id='".$del."'";
if(!mysql_query($delete_query))
{
echo "error while deleting";
}
mysql_close($con);
?>
我对阿贾克斯真的很陌生。当我单击应该删除用户的链接时,它不会删除任何内容。它不是从数据库中删除标签或从页面中删除链接。我错过了什么?任何帮助,将不胜感激。谢谢。