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执行。这是为什么呢?由于定时器是异步的,异步任务会在当前脚本的所有同步任务执行完才会执行。如果同步代码中含有死循环,即将上例的注释去掉,那么这个异步任务就不会执行,因为同步任务阻塞了进程。