在您的 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 响应。