settimeout和ajax,关于ajax与setTimeout的执行顺序问题

function getXHR(){

var xhr=null;

if(window.XMLHttpRequest){

xhr=new XMLHttpRequest();

} else if (window.ActiveXObject){

try{

xhr=new ActiveXObject("Msxml2.XMLHTTP");

} catch(e) {

try {

xhr=new ActiveXObject("Microsoft.XMLHTTP");

} catch (e) {

alert("您的浏览器暂不支持Ajax");

}

}

}

return xhr;

}

//ajax与setTimeout排队问题

function ajax(url,method){

var xhr=getXHR();

xhr.onreadystatechange=function(){

console.log("xhr.readyState:"+this.readyState);

}

xhr.οnlοadstart=function(){

console.log("onloadStart");

}

xhr.onload = function(){

console.log("onload");

}

xhr.open(method,url,true);

xhr.setRequestHeader("Cache-Control",3600);

xhr.send();

}

var timer=setTimeout(function(){

console.log("setTimeout");

},0);

ajax("http://localhost:63342/project1/js3/html/Ajax%E5%AD%A6%E4%B9%A0.html?_ijt=i9plfqpg77fjialq6b8140t8d3","GET");

console.warn("这里的log并不是最先打印出来的");

为什么会是这么一种结果?哪位大神可以具体解释一下?

bVKRbc?w=488&h=188

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值