Javascript-Ajax 无法发送任何数据


Javascript-Ajax not able to send any data

我在使这部分代码工作时遇到了麻烦,基本上我想调用这个将变量发送到 PHP 页面的函数。我测试了变量是否存在,并且还测试了我的 php 页面是否接受应有的信息,但是我无法使这个 Ajax 东西工作。

function ajaxRequest(myname) {
var AJAX = null; // Initialize the AJAX variable.
if (window.XMLHttpRequest) 
{ // Does this browser have an XMLHttpRequest object?
    AJAX=new XMLHttpRequest(); // Yes -- initialize it.
} else 
{ // No, try to initialize it IE style
    AJAX=new ActiveXObject("Microsoft.XMLHTTP"); // Wheee, ActiveX, how do we format c: again?
} // End setup Ajax.
if (AJAX==null) 
{ // If we couldn't initialize Ajax...
    alert("Your browser doesn't support AJAX."); // Sorry msg.
return false // Return false, couldn't set up ajax
}
AJAX.onreadystatechange = function() 
{ // When the browser has the request info..
    if (AJAX.readyState==4 || AJAX.readyState=="complete") 
    { // see if the complete flag is set.
        callback(AJAX.responseText, AJAX.status); // Pass the response to our processing function
    } // End Ajax readystate check.
}
alert("Alert1");
var url='http://localhost/main.php?Name=myname';    
AJAX.open("POST", url, true); // Open the url this object was set-up with.
alert("Alert2");
AJAX.send(); // Send the request.

}

这是我的 php 部分,应该接受变量

<?php
$var=$_GET['Name'];
echo $var;
?>

好的,首先您需要将请求更改为 GET from POST喜欢

AJAX.open("GET", url, true); // Open the url this object was set-up with.

您还需要更新此行从

var url='http://localhost/main.php?Name=myname'; 

var url='http://localhost/main.php?Name='+myname; 

我的完整脚本是:

<script type="text/javascript">
    function ajaxRequest(myname) {
        var AJAX = null; // Initialize the AJAX variable.
        if (window.XMLHttpRequest) 
        { // Does this browser have an XMLHttpRequest object?
            AJAX=new XMLHttpRequest(); // Yes -- initialize it.
        } else { // No, try to initialize it IE style
            AJAX=new ActiveXObject("Microsoft.XMLHTTP"); // Wheee, ActiveX, how do we format c: again?
        } // End setup Ajax.
        if (AJAX==null) 
        { // If we couldn't initialize Ajax...
            alert("Your browser doesn't support AJAX."); // Sorry msg.
            return false // Return false, couldn't set up ajax
        }
        AJAX.onreadystatechange = function() 
        { // When the browser has the request info..
            if (AJAX.readyState==4 || AJAX.readyState=="complete") 
            { // see if the complete flag is set.
                callback(AJAX.responseText, AJAX.status); // Pass the response to our processing function
            } // End Ajax readystate check.
        }
        alert("Alert1");
        var url='http://localhost/main.php?Name='+myname;    
        AJAX.open("GET", url, true); // Open the url this object was set-up with.
        alert("Alert2");
        AJAX.send(); // Send the request.
    }
</script>

您可能还缺少回调函数,因此请添加它,使其看起来像这样

function callback(x, y) {
    alert(x);
}

并通过以下方式调用您的 AJAX 函数

ajaxRequest("ashley");

这是您需要的主.php代码(即使这不是您应该使用 AJAX 的目的

<?php 
session_start();
if(isset($_GET["Name"])) {
   $_SESSION["Name"] = $_GET["Name"];
}
if(isset($_SESSION["Name"])) {
   echo $_SESSION["Name"];
} else {
   echo "The AJAX has not been run!";
}
?>

有两种方法可以将 ajax 请求发送到服务器获取或发布

1. 获取方法:

var url='http://localhost/main.php?Name='+myname; // you can add any numner of vars here
AJAX.open("GET", url, true); 
AJAX.send();

主代码.php

    if(!empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') {
        echo $_GET['Name'];
    }

2. 开机自检方法:

AJAX.open("POST","ajax_test.asp",true);
AJAX.setRequestHeader("Content-type","application/x-www-form-urlencoded");
AJAX.send("Name="+myname);

主代码.php

if(!empty($_SERVER['HTTP_X_REQUESTED_WITH']) && strtolower($_SERVER['HTTP_X_REQUESTED_WITH']) == 'xmlhttprequest') {
    echo $_POST['Name'];
}