簡體   English   中英

無法發送 XMLHttpRequest

[英]Can't send XMLHttpRequest

我正在嘗試使用 vanilla javascript ajax 刪除數據。 將帶有 id 值的 POST 請求發送到 php 文件后。 每次它在控制台中打印“錯誤”。

HTML

<div class="deleteButton" onclick="showAllert(this)" id="1">
  <i class="fa-solid fa-trash-can fa-2x" style="color:#A81E22" title="delete"></i>
</div>

JAVASCRIPT

 <script>     
        function showAllert(a) {

            // sent delete request
            var dataId = a.getAttribute("id");
            var dataId = parseInt(dataId);

            var xhr = new XMLHttpRequest();
            xhr.open('POST', 'includes/vehicles/del-veh.php', true);
            // xhr.responseType = 'json';
            xhr.onload = () => {
                if(xhr.status === 200) {
                    console.log(xhr.response);
                    location.reload();
                }else {
                    console.log("There was a problem");
                }
            }
            var data = JSON.stringify({id: dataId});
            xhr.send(data);
                    
        }
    </script>

PHP

<?php
//Connection statement
require_once('../../Connections/ukcd.php');
$data = json_decode(file_get_contents('php://input'), true);

if(!empty($data["id"])) {
    // Required variables
    $vehid = $data['id'];
    echo "success";
}else {
    echo "error";
}

//AUTOEXECUTE METHOD
$delveh = $ukcd->prepare('DELETE FROM a_ukcd_client_vehicles WHERE clientveh_id = ?');
$result = $ukcd->execute($delveh, $vehid);

以 urlencoded 格式發送 POST 數據:

 <script>     
        function showAllert(a) {

            // sent delete request
            var dataId = a.getAttribute("id");
            var dataId = parseInt(dataId);

            var xhr = new XMLHttpRequest();
            xhr.open('POST', 'includes/vehicles/del-veh.php', true);
            // xhr.responseType = 'json';
            xhr.onload = () => {
                if(xhr.status === 200) {
                    console.log(xhr.response);
                    location.reload();
                }else {
                    console.log("There was a problem");
                }
            }
            // var data = JSON.stringify({id: dataId});
            xhr.send(`id=${dataId}`);
                    
        }
    </script>

在您的 PHP 腳本中:

<?php
//Connection statement
require_once('../../Connections/ukcd.php');
$id= $_POST['id'];

if(!empty($id)) {
    // Required variables
    $vehid = $id;
    echo "success";
}else {
    echo "error";
}

//AUTOEXECUTE METHOD
$delveh = $ukcd->prepare('DELETE FROM a_ukcd_client_vehicles WHERE clientveh_id = ?');
$result = $ukcd->execute($delveh, $vehid);

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM