layer.load方法不加载,Ajax为同步时,layer.load方法不加载

问题:Ajax为同步时,layer.load方法不加载 原因:Jquery ajax 同步阻塞引起的UI线程阻塞。浏览器的渲染(UI)线程和js线程是互斥的,在执行js耗时操作时,页面渲染会被阻塞掉。当我们执行异步ajax的时候没有问题,但当设置为同步请求时,其他的动作(ajax函数后面的代码,还有渲染线程)都会停止下来。

方法一:设置ajax为异步

async:false

方法二:使用deffer对象和$.when()

这样既可以ajax设为异步,保证了loading的正常显示,又可以保证在ajax走完再加载页面。因为$.when().done()会在deffer.resolve()之前的代码全部走完后才走done中的代码。 上代码:

其中用到了**deferred**对象 具体内容可以看: 链接: http://www.ruanyifeng.com/blog/2011/08/a_detailed_explanation_of_jquery_deferred_object.html

由于ajax为同步时点击切换比较卡。能用异步最好还是用异步,用deferred对象后就可以把async换成true了。$.when()函数只接受deferred对象,所以我们在toGetData中需要先创建对象,再return就解决了。defer.resolve(ret)用于控制ajax何时结束,比如我执行完赋值操作结束ajax,进入.done()中的回调函数,它还可以把数据ret也带出来使用,这里我没有用到。所以它能保证deffer.resolve之前的代码执行完再执行回到函数,async设为true也没任何影响。 这样就完美解决了因为ajax阻塞线程导致loading层出不来的问题啦。

精彩内容

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: