微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jsonp的问题

jsonp不支持async:false属性错误代码块如下:

$.ajax({
    url : 'xxx',data : {
        xxx : xxx,xxx : xxx
    },dataType : 'jsonp',jsonpCallback : 'callback',async : false,//此处是jsonp不支持的参数
    success : function (data) {
        //do something;
    }
});
jquery封装的ajax会返回数据,返回的数据如果是jsonp格式的会动态的封装在js代码里面,以支持跨域

-----------------------------------------华丽分割线-----------------------------------------------------------

setTimeout(function() {
    console.log('taskA,asynchronous');
},0);
console.log('taskB,synchronize');
//while(true);

-------ouput-------
taskB,synchronize
taskA,asynchronous


我们可以看到,定时器延时的时间明明为0,但taskA还是晚于taskB执行。这是为什么呢?由于定时器是异步的,异步任务会在当前脚本的所有同步任务执行完才会执行。如果同步代码中含有死循环,即将上例的注释去掉,那么这个异步任务就不会执行,因为同步任务阻塞了进程。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐