我在使用PHP,Javascript和AJAX制作删除系统时遇到了麻烦。我之前做过,但这次PHP和AJAX不会联系,Javascript脚本也不会做任何事情。PHP和AJAX不能一起工作
在Javascript文件中(server-log.js)警告某些东西不起作用,它不会来。这也不适用于AJAX/PHP处理程序文件(server-log.handler.php)。 控制台错误没有给出任何错误作为回报,所有文件中的URL也是正确的。这是因为我可以从Chrome中
JS脚本(服务器log.js)找到控制台错误的每个文件:
$('.btn btn-xs btn-danger').click(function(){
var press = $.this.attr('id');
var press_url = 'action=delete&id='+press;
$.ajax({
type: 'POST',
url: 'panel/includes/handlers/server-log.handler.php',
data: press_url,
success: function(responseText)
{
$.parseJSON(responseText);
/* If and else controlling system */
if(responseText.indexOf(1) > -1)
{
$("#danger").append('<strong>Helaas!</strong> Het is niet gelukt om de gevraagde log rij te verwijderen');
}
else if(responseText.indexOf(2) > -1)
{
$("#danger").append('<strong>Helaas!</strong> Het opgegeven ID nummer is niet geldig');
}
else if(reponseText.indexOf(100) > -1)
{
$("#success").append('<strong>Goed!</strong> De gevraagde log is succesvol verwijderd');
}
else
{
$("#info").append('<strong>Info:</strong> Er is helaas een onbekende fout opgetreden <i>2255200914</i>');
}
}
});
});
HTML部分(服务器log.php)
<div class="alert alert-success" style="display: none;" id="success"></div>
<div class="alert alert-danger" style="display: none"; id="danger"></div>
<div class="alert alert-info" style="display: none;" id="info"></div>
<div class="error-log sscroll">
<ul>
<form method="post">
<?php
while($arrayLogs = $arrayqLogs->fetch_array())
{
?>
<li>
<span class="green">[<?php echo $arrayLogs['date']; ?>]</span>
<span class="red">[<?php echo $arrayLogs['action']; ?>]</span>
[<?php echo $arrayLogs['name']; ?>] <?php echo $arrayLogs['url']; ?>
<button class="btn btn-xs btn-danger" name="deleting" id="<?php echo $arrayLogs['id']; ?>"><i class="fa fa-times"></i></button>
</li>
<?php
}
?>
</form>
</ul>
</div>
PHP的处理程序部分(服务器log.handler.php)
<?php
include_once '../config.php';
if(isset($_POST['action']) && $_POST['action'] == 'delete')
{
$intAction = trim($_POST['id']);
$error = array();
$bolean = false;
# Prepared statement
$stmt = $mysqli->prepare("SELECT id,name,action,url,date FROM logs WHERE id = ?");
$stmt->bind_param('i', $intAction);
$stmt->execute();
$intStatement = $stmt->num_rows();
$stmt->close;
/* Controlling part */
if($intStatement == 0)
{
$error[] = 1;
$bolean = true;
}
elseif(!ctype_digit($intAction))
{
$error[] = 2;
$bolean = true;
}
// Deleting and notifying
if($bolean == false)
{
$stmt = $mysqli->prepare("DELETE FROM logs WHERE id = ?");
$stmt->bind_param('i', $intAction);
$stmt->execute();
$stmt->close();
# Returning error code
$error[] = 100;
}
/* Returning the value in a readable way */
header('Content-Type: application/json');
echo json_encode($error);
}
?>
所以这不是我第一次做这在我的网站,b我也没有经常这样做,所以我认为我做了很多错误的事情。我非常感谢你们的帮助,英语不是我的母语,所以对于任何语法/拼写错误的单词都很抱歉。
您是否发现'console.log()'停止响应的地步? – brasofilo 2014-09-20 21:29:48
你为什么执行'SELECT'查询,但从来没有使用它返回的结果? – Barmar 2014-09-20 21:40:14
@brasofilo如果我把它放在点击函数之前,那么我只能得到3个回应中的1个... – RezaMO 2014-09-20 21:47:24