[英]Ajax - jQuery and Ajax errors/not working
我正在构建一个网页,其中包含一个div
,其中包含通过 PHP 从 MySql 数据库中检索到的一些数据。 这个 div 显示了一些产品,在它的左边有一个带有不同类别的简单导航栏。 我试图做的是,当用户单击此导航栏的某个类别时, div
的内容将发生变化,显示该类别的所有产品都存储在 db 中。 所以我尝试使用 Ajax(顺便说一句,我的第一次),但我似乎无法让它工作。 我的项目结构是这样的:
父目录
index.php 文件链接到 index.js 和 products-ajax.js 但是,我已经尝试在 index.js 和 index.php 中包含 Ajax 代码行,但我无法让它从products-ajax.php 任何帮助表示赞赏。
这是我的测试代码的样子:
/* THIS IS THE products-ajax.js */ $(document).ready(function(){ $('.products-list li').click(function(){ $.post("products-ajax.php", {p: "Product name"}, success: function(data){alert(data)} ); }); });
<?php /* THIS IS THE products-ajax.php */ $p = $_POST['p']; echo $p; ?>
我意识到我的浏览器的调试器说缺少括号:
$('.products-list li').click(function(){
//The debugger says HERE v should go a parentheses
$.post("products-ajax.php", {p: "Product name"}, success: function(data{alert(data)});
});
使用$.ajax()
而不是$.post()
,您可以添加一个错误处理程序,它会给您提供宝贵的信息(也许您可以使用$.post()
,但我不熟悉这个函数,afaik 是只是$.ajax()
的快捷方式)。 它可能是这样的:
var request = $.ajax({
url: "products-ajax.php",
method: "POST",
data: { p: "Product name" }
});
request.done(function( data ) {
alert( data );
});
request.fail(function( jqXHR, textStatus ) {
alert( "Request failed: " + textStatus );
});
编辑:并且更喜欢console.log()
而不是alert()
进行调试。 特别是对于异步交互, alert()
有时会导致意外......
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.