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

转载于:https://www.cnblogs.com/luoyanli/archive/2012/10/08/2714927.html

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

表情包
插入表情
评论将由博主筛选后显示,对所有人可见 | 还能输入1000个字符
©️2021 CSDN 皮肤主题: 编程工作室 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值