php遍历插入数据后,前端ajax回调接收不到返回值

html
 <form class="layui-form" action="" method="post" id="frm1" name="frm1">    
<div class="layui-form-item">           
                  <label for="L_email" class="layui-form-label">
                          <span class="x-red">span>批量idlabel>
                      <div class="layui-input-inline" style="width:440px">
                           <textarea id="ids" name="ids" autocomplete="off" class="layui-input" style="width:535px;" readonly >textarea>        
                      div>
     div>
 <div class="layui-form-item">
                      <label for="L_repass" class="layui-form-label">
                      label>
                      <button type="button" id="adddata" class="layui-btn" lay-submit lay-filter="add" >提交 button>
                      <button type="reset" onclick="formReset()" class="layui-btn layui-btn-primary">重置button>
                  div>
form>
<script>
//提交
        form.on('submit(add)', function(data){
            $.ajax({ 
                async : false,
                url:'./tijiao_do1.php',   
                method:'post',   
                data:data.field,    
                dataType:'JSON',             
                success: function(res) {
    var successCount = 0;
    var failedCount = 0;
    for (var i = 0; i < res.length; i++) {
        if (res[i].code == '0') {
            successCount++;
        } else {
            failedCount++;
        }
    }
    if (successCount > 0) {
        layer.msg("成功提交" + successCount + "条数据", { icon: 1, time: 1000 }, function() { location.reload(); });
    }
    if (failedCount > 0) {
        alert("提交失败" + failedCount + "条数据");
    }
    $("#adddata").removeAttr("disabled");
},       
                    error:function (data) {
 
                    }     
            }); 
            return false;
        });
script>

```php
tijiao_do1.php

  $gain_name=$_POST['gain_name'];
  $ids = $_POST['ids '];
require './connect_db.php';
  
  $ids =explode("\n",$ids );//分隔换行的数据,如果是逗号隔开的则用$sn=explode(',',$sn);
  //$ids =explode(PHP_EOL,$ids );//分隔换行的数据
  for($i=0;$i$ids );$i++)
  if(!empty(trim($ids [$i])))   //判断是否为空
   { 
      $sql = "INSERT INTO sev_order (  sn,gain_name) VALUES (  '$ids [$i]', '$gain_name') ";   
       if ($result = $conn->query($sql)) {
        $success[] = array('code' => '0', 'msg' => '发送成功');
    } else {
        $failed[] = array('code' => '-1', 'msg' => '发送失败');
    }
    echo json_encode(array_merge($success, $failed));
   }
  ?>


在您的 PHP 代码中,您将每个值插入数据库时都打印出 JSON 响应。这将导致您向客户端发送多个 JSON 响应,这可能会干扰您的 Ajax 回调函数。您可以在循环之外定义一个 JSON 数组,并将插入操作的结果添加到该数组中,循环结束后打印出整个数组,如下所示:

<?php
$gain_name = $_POST['gain_name'];
$ids = $_POST['ids'];

require './connect_db.php';

$ids = explode("\n", $ids);
$success = array();
$failed = array();

for ($i = 0; $i < count($ids); $i++) {
    if (!empty(trim($ids[$i]))) {
        $sql = "INSERT INTO sev_order (sn, gain_name) VALUES ('$ids[$i]', '$gain_name')";
        if ($result = $conn->query($sql)) {
            $success[] = array('code' => '0', 'msg' => '发送成功');
        } else {
            $failed[] = array('code' => '-1', 'msg' => '发送失败');
        }
    }
}

echo json_encode(array_merge($success, $failed));
?>

此外,您的 Ajax 回调函数检查每个响应的 code 值,以确定操作是否成功。但是,您在 PHP 代码中始终将 code 值设置为 0,这意味着无论操作是否成功,您都会将其视为成功。如果您要在错误发生时发送有意义的错误消息,可以在 else 分支中设置一个不同的 code 值,如下所示:


<?php
$gain_name = $_POST['gain_name'];
$ids = $_POST['ids'];

require './connect_db.php';

$ids = explode("\n", $ids);
$success = array();
$failed = array();

for ($i = 0; $i < count($ids); $i++) {
    if (!empty(trim($ids[$i]))) {
        $sql = "INSERT INTO sev_order (sn, gain_name) VALUES ('$ids[$i]', '$gain_name')";
        if ($result = $conn->query($sql)) {
            $success[] = array('code' => '0', 'msg' => '发送成功');
        } else {
            $failed[] = array('code' => '-1', 'msg' => '发送失败:' . $conn->error);
        }
    }
}

echo json_encode(array_merge($success, $failed));
?>

在这种情况下,如果出现错误,您将在客户端看到一个包含错误消息的 JSON 响应。

回答不易,求求您采纳点赞哦 感激不尽

在代码中,后端PHP文件tijiao_do1.php是通过echo json_encode()返回JSON格式数据给前端的。但是在代码中,PHP文件每次插入一条数据,就会输出一次JSON格式数据,这样会导致返回多个JSON格式数据,从而导致前端无法正确解析数据。因此,需要将JSON格式数据存储在数组中,等到循环结束后,再一次性将数组中的数据输出。

下面是修改后的PHP代码,将JSON格式数据存储在数组$result中,循环结束后,将数组中的数据一次性输出给前端:

<?php
$gain_name = $_POST['gain_name'];
$ids = $_POST['ids'];

require './connect_db.php';

$ids = explode("\n", $ids); //分隔换行的数据
$result = array();
for ($i = 0; $i < count($ids); $i++) {
    if (!empty(trim($ids[$i]))) { //判断是否为空
        $sql = "INSERT INTO sev_order (sn,gain_name) VALUES ('$ids[$i]', '$gain_name') ";
        if ($conn->query($sql)) {
            $success[] = array('code' => '0', 'msg' => '发送成功');
        } else {
            $failed[] = array('code' => '-1', 'msg' => '发送失败');
        }
    }
}

$result = array_merge($success, $failed);
echo json_encode($result);
?>

另外,前端代码中的success函数中调用了location.reload()方法,这会刷新页面,可能导致前端无法正确获取返回数据。建议将其去掉,以免影响数据的正常处理。

不知道你这个问题是否已经解决, 如果还没有解决的话:

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^