XMLHttpRequest将变量传递给php脚本

时间:2012-11-27 16:09:54

标签: php javascript xmlhttprequest

我正在尝试使用XMLHttpRequest将变量传递给php脚本,然后让php回显它。我无法理解为什么它不起作用,有人可以帮助我。 这是Javascript。

<script language="javascript" type="text/javascript">
    // Browser Support 
function Heatctrl(heatMode){
    var heatControlRequest;

    try{
        //Good Browsers
        heatControlRequest = new XMLHttpRequest();
    } catch (e) {
        //Internet Explorer
        try{
            heatControlRequest = new ActiveXObject("Msxml2.XMLHTTP");
        } catch (e) {
            try{
                heatControlRequest = new ActiveXObject("Microsoft.XMLHTTP");
            }catch (e) {
                alert("Brower not supported");
                return false;
            }
        }
    }


    // Function to receive data from server and store in variable
    heatControlRequest.onreadystatechange = function(){
        if (heatControlRequest.readystate == 4){
            alert(heatControlRequest.responseText);
            //document.getElementById("controlMode").innerHTML=heatControlRequest.responseText;
            //var heatControlResponse = heatControlRequest.responseText;
        }
    }
    var url = "heatControl.php?heatmode="+heatMode;
    // Send the request
    heatControlRequest.open("GET", url, true);
    heatControlRequest.send();
}   
</script>

HTML

    <div id="boilerButtons">
    <button type="button" onclick="Heatctrl('On')">Heating On</button>
    <button type="button" onclick="Heatctrl('Off')">Heating Off</button>
    <button type="button" onclick="Heatctrl('Boost')">Boost</button>
</div>

和php

<?php
$controlMode = $_GET['heatmode'];
echo $controlMode; 
?>

我非常感谢任何帮助,我从事电子工作而不是编程工作,而且我现在已经在这方面苦苦挣扎了两天。

1 个答案:

答案 0 :(得分:3)

问题在于这一行:

if (heatControlRequest.readystate == 4){
                            ^ this should be an uppercase S

应该是:

if (heatControlRequest.readyState == 4){ 

来自docs

  

XMLHttpRequest对象可以处于多种状态。 readyState属性必须返回当前状态。