[英]jQuery $.getJSON not returning data
我正在通过$ .getJSON对我的PHP脚本进行AJAX调用。 问题是,PHP返回的是json编码的数据,但是我的脚本根本没有console.loging任何东西。
function Club(){
this.URL = "http://localhost/imp03/includes/ajaxCall.php";
}
Club.prototype.loadData = function(){
$.getJSON(Club.URL, function(data){
console.log(data);
});
}
控制台中没有错误,这是我的PHP脚本。
$db = new Database(HOST, USER, PASS, DB);
$array = $db->getData();
header('Content-Type: application/json');
echo json_encode($array);
exit;
这是我的数据库类中的方法,负责获取数据
public function getData(){
try{
$sql = $this->db->prepare("SELECT * FROM inlever3");
$sql->execute();
$result = $sql->fetchAll();
return $result;
} catch(PDOException $e){
echo $e;
return false;
}
}
Club
是该函数,它没有URL
属性。
Club.prototype.loadData = function(){
$.getJSON(Club.URL, function(data){
console.log(data);
});
}
应该
Club.prototype.loadData = function(){
// here change Club.URL to this.URL
$.getJSON(this.URL, function(data){
console.log(data);
});
}
并像这样使用它:
var club = new Club();
club.loadData();
刚刚尝试过,它可以按预期工作:
您需要在$.getJSON()
调用中使用this.URL
而不是Club.URL
test.php
<?php
if (isset($_GET['loadData']))
{
// dummy data
exit(json_encode(
array('hello' => 'world')
));
}
?>
<script type="text/javascript" src="http://code.jquery.com/jquery-1.11.0.min.js"></script>
<script type="text/javascript">
function Club(){
this.URL = "test.php?loadData";
}
Club.prototype.loadData = function(){
$.getJSON(this.URL, function(data){
console.log(data);
});
}
var c = new Club();
c.loadData();
</script>
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.