使用 JSON 从 PHP 文件获取数据失败


getting data from PHP file with json is failing

我无法从PHP文件中获取每个数据,我总是遇到AJAX故障,我尝试了很多事情,并为此寻找了一些页面,但我找不到任何解决方案,这是我最后的地方。这是我的jQuery函数:

$(document).ready(function () {
$(function () {
$('a[class="someclass"]').click(function(){
   var somedata = $(this).attr("id");
   $.ajax({
      type: "POST",
      url: "foo.php",
      data: {"id": somedata}, 
      dataType:"json",
      success: function(data){
         e.preventDefault();
         $("#data1").html(data[0]);
         $("#data2").html(data[1]);
         $("#data3").html(data[2]);
         $("#data4").html(data[3]);
      },
      error:function(){
          alert("AJAX request was a failure");
      }
    });
    });
    });
});

这是我的PHP文件:

$data = $_POST['id'];
$con = mysqli_connect('localhost','root','','database');
if (!$con) {
  die('Could not connect: ' . mysqli_error($con));
}
mysqli_select_db($con,"database");
$sql="SELECT * FROM table WHERE id = '".$data."'";
$result = mysqli_query($con,$sql);

while($row = mysqli_fetch_array($result)) {
  $jsondata1 = array($row['data1'], $row['data2'], $row['data3'],  $row['data4']); 
  echo json_encode($jsondata1);
 }
mysqli_close($con);

我认为没有必要共享HTML文件,但是如果您愿意,我可以与您共享。谢谢!

您正在覆盖循环中的数组值和 echo $jsondata 1,因此您将发送许多不同的数组,并在循环内使用 echo,请尝试以下代码:

 $jsondata1 = array();
 while($row = mysqli_fetch_array($result)) {
    $jsondata1[] = array($row['data1'], $row['data2'], $row['data3'],  $row['data4']); 
 }
 echo json_encode($jsondata1);

e.preventDefault();是一个问题。 e未定义,如果是默认操作,则在调用成功函数时已经发生。尝试

$('a[class="someclass"]').click(function(e){
    e.preventDefault();
   var somedata = $(this).attr("id");
   $.ajax({
      type: "POST",
      url: "foo.php",
      data: {"id": somedata}, 
      dataType:"json",
      success: function(data){
         $("#data1").html(data[0]);
         $("#data2").html(data[1]);
         $("#data3").html(data[2]);
         $("#data4").html(data[3]);
      },
      error:function(){
          alert("AJAX request was a failure");
      }
    });
    });
    });
});

您需要对完整的响应进行编码。当您回显每个编码时,它将不起作用。做类似的事情

$jsonArray = array();
while(){
    array_push($jsonArray, array($row['data1'], $row['data2']);
}
echo json_encode($jsonArray);
您需要

做的是将这些中间变量分配给数组并使用 json 编码对该数组进行编码以返回时,您会多次调用json_encode。

.PHP:

$data = $_POST['id'];
$con = mysqli_connect('localhost','root','','database');
if (!$con) {
  die('Could not connect: ' . mysqli_error($con));
}
mysqli_select_db($con,"database");
$sql="SELECT * FROM table WHERE id = '".$data."'";
$result = mysqli_query($con,$sql);
$jsondata1 = [];
while($row = mysqli_fetch_array($result)) {
    $jsondata1[] = array($row['data1'], $row['data2'], $row['data3'],  $row['data4']); 
}
mysqli_close($con);
die(json_encode($jsondata1));

JavaScript:

$(document).ready(function () {
var doc = $(document);
doc.on('click', 'a.someclass', function(e){
    e.preventDefault();
    var somedata = $(this).attr("id");
   $.ajax({
      type: "POST",
      url: "foo.php",
      data: {"id": somedata}, 
      dataType:"json",
      success: function(data){
          $("#data1").html(data[0]);
          $("#data2").html(data[1]);
          $("#data3").html(data[2]);
          $("#data4").html(data[3]);
      },
      error:function(){
          alert("AJAX request was a failure");
      }
  });
});

});