Ajax--readyState一直为0

readyState 一直为0表示对象已建立,连接未建立的状态

我写的代码:

    function LoadXMLDoc(url,scope,orderID){
        if(window.XMLHttpRequest){
            xmlhttp = new XMLHttpRequest();
        }else if(window.ActiveXObject){
            xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
        }
        alert(xmlhttp);
        if(xmlhttp!=null){
            xmlhttp.onreadystatechange = changeState();
            xmlhttp.open("post",url,true);
            xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
            xmlhttp.send("scope="+scope+"&orderID="+orderID);
        }
    }

    function changeState(){
        alert("q");
        alert('state:'+xmlhttp.readyState);
        alert('status:'+xmlhttp.status);
        if(xmlhttp.readyState==4 && xmlhttp.status==200){
            alert("Q");
            window.location.reload();
        }
    }

后来终于解决了,是因为这句:xmlhttp.onreadystatechange = changeState();这样写的话xmlhttp.onreadystatechange为将changeState的返回值赋给xmlhttp.onreadystatechange;而xmlhttp.onreadystatechange为当状态改变时调用函数changeState,所以应该这样写:xmlhttp.onreadystatechange=changgeState,如果有参数的话这样写:xmlhttp.onreadystatechange = functiong (){changeState(a,b);};

posted @ 2012-10-08 11:08  小嫩芽儿  阅读(8801)  评论(0编辑  收藏  举报