0

我试图让我连接到一个 php 文件,但我没有收到来自服务器的任何响应有什么问题吗?

function request(){
    // Create our XMLHttpRequest object
var hr = new XMLHttpRequest();

// Create some variables we need to send to our PHP file
var url = "http://people.dsv.su.se/~pierre/courses/05_ass/ip3/3/3.7.1/example.php";
var number1 = document.getElementById("number1").value;
var number2 = document.getElementById("number2").value;
var vars = "?number1="+number1+"&number2="+number2
hr.open("POST", url, true);

// Set content type header information for sending url encoded variables in the request
hr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
// Access the onreadystatechange event for the XMLHttpRequest object

hr.onreadystatechange = function() {
   if(hr.readyState == 4 && hr.status == 200) {
   var return_data = hr.responseText;

document.getElementById("result").innerHTML = return_data;
}
}
// Send the data to PHP now... and wait for response to update the status div
hr.send(vars); // Actually execute the request
document.getElementById("result").innerHTML = "processing...";
 }

我没有从服务器得到任何答案是我做错了吗?

我现在尝试用 jquery 编写它,但仍然没有来自服务器的响应

$(document).ready(function() {

// Skicka nummrerna vid klick på #calculate
$('#calculate').click(function() {

var url = "http://people.dsv.su.se/~pierre/courses/05_ass/ip3/3/3.7.1/example.php?";
var number1 = document.getElementById("number1").value;
var number2 = document.getElementById("number2").value;
var numbers = url + number1 + "&" + number2
if (window.XMLHttpRequest)
{// Kod för nya webbläsare
    xmlhttp=new XMLHttpRequest();
}
else {//om det inte är en nyare webbläsare
    xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function() {
    if (xmlhttp.readyState==4 && xmlhttp.status==200)
    {
        // Skriv ut svaret från servern i result
        document.getElementById("result").innerHTML=xmlhttp.responseText;
    }
}
xmlhttp.open("GET",numbers,true);
xmlhttp.send();
alert(numbers);
});
});
4

3 回答 3

2

您正在格式化您的变量,就好像您在 GET 请求中使用它们一样,然后将您的请求设置为 POST。

[编辑:展示评论]

尝试更改这两行。

hr.open("GET", url + vars, true);

hr.send();

[编辑] 包含更改的完整原始代码

function request(){
        // Create our XMLHttpRequest object
    var hr = new XMLHttpRequest();

    // Create some variables we need to send to our PHP file
    var url = "http://people.dsv.su.se/~pierre/courses/05_ass/ip3/3/3.7.1/example.php";
    var number1 =22;// document.getElementById("number1").value;
    var number2 =22;// document.getElementById("number2").value;
    var vars = "?number1="+number1+"&number2="+number2
    hr.open("GET", url + vars, true);

    // Set content type header information for sending url encoded variables in the request
    //hr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
    // Access the onreadystatechange event for the XMLHttpRequest object

    hr.onreadystatechange = function() {
           if(hr.readyState == 4 && hr.status == 200) {
               var return_data = hr.responseText;

                document.getElementById("result").innerHTML = return_data;
            }
    }
    // Send the data to PHP now... and wait for response to update the status div
    hr.send(); // Actually execute the request
    document.getElementById("result").innerHTML = "processing...";
 }
于 2013-05-15T12:17:38.247 回答
0

以下是 jQuery 格式的完整代码:

$(document).ready(function () {
    $('#calculate').click(function () {
        var url = "http://people.dsv.su.se/~pierre/courses/05_ass/ip3/3/3.7.1/example.php?number1=" + $("#number1").val() + "&number2=" + $("#number2").val();
        $.ajax(url, {
            complete: function (data, textStatus, jqXHR) {
                //Put the code that handle the response here
                $("#result").html(data.responseText);
            }
        });
    });
});
于 2013-05-15T15:56:38.220 回答
0

You need to send() your request with the data as the param. Something like:

params = "number1="+number1+"&number2="+number2;
hr.send(params);
于 2013-05-15T12:31:11.617 回答