被这个问题困扰了一段时间,不知道我做错了什么。以下代码使用 bootbox.js 按钮删除我正在使用的社交网络上的帖子:
<script>
$(document).ready(function() {
$('#post<?php echo $p_id; ?>').on('click', function() {
bootbox.confirm("Are you sure you want to delete this post?", function(result) {
$.post("./includes/form_handlers/delete_post.php?post_id=<?php echo $p_id; ?>", {result:result});
/*This breaks*/
//if(result)
//location.reload();
});
});
});
</script>
出于某种原因,调用 location.reload 似乎阻止了我的 php 处理程序执行 sql 语句(这是一个简单的更新查询)。奇怪的是,当它被注释掉时,数据库更新没有问题。
有人可以向我解释一下并可能推荐一个解决方案吗?
最佳答案
您在 HTTP 调用和页面重新加载之间进行竞争。页面重新加载将终止 http 请求,它不会等待它完成。
所以解决方案是将重新加载行移到成功回调中。
$.post("./includes/form_handlers/delete_post.php?post_id=<?php echo $p_id; ?>", {result:result})
.done( function(){ window.location.reload(true); });
关于javascript - 使用 location.reload() 似乎可以防止 php 更新数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44803462/