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);};


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM