jQuery.ajax() method's async option deprecated, what now?
从jQuery 1.8开始,不推荐在jQuery.ajax()中使用
但是,在后台正在进行的AJAX通信中,您在"加载屏幕"中看到了多少个网页? 我可能已经看过数千个。
我的情况是我正在编写一个需要加载语言文件的移动应用程序。 在开始时,我加载语言文件,然后从语言文件中检索按钮和其他GUI元素的文本。
这对我来说真的很糟糕。 因为如果缺少语言文件,则不应出现GUI。 那么我该如何解决呢? 把我所有的代码都放在
解决方案是手动添加覆盖以防止用户与界面交互,然后在完成AJAX查询后将其删除。
1 2 3 4 5 6 7 8 9 10 11 | $(function() { show_overlay(); $.ajax({ // Query to server }).done(function() { // Verify good data // Do stuff remove_overlay(); }); }); |
我在票证中看到了关于这个参数弃用的官方讨论,这是我所理解的:
-
问题是为同步AJAX实现Promises(1)会给它们带来开销。
-
有许多同步AJAX的现实使用案例,例如在页面卸载之前保留状态。因此,此功能将保留,但您使用它的方式可能会改变。
-
当
async false 时,最近的解决方案(登陆1.8?)仅支持回调(但不支持Promises)。
总结:如果必须,继续使用
我敢打赌,在等待AJAX??调用时,这1000个页面中的许多页面实际上并没有阻止UI。相反,他们可能在调用时使用等待屏幕模糊UI,然后在响应处理程序上删除它。
隐藏UI的方法有很多种(你甚至可以使用设置为Modal的jQuery UI对话框,没有转义或关闭按钮),所以我会把这个决定留给你。但代码的布局将是这样的:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | var someFunction = function () { // any pre-conditions to the logic // obscure the UI here $.ajax({ url: 'ajax/test.html', success: function(data) { // handle the response // show the UI again }, error: function(data) { // handle the response // show the UI again } }); } |
我确信有多种方法可以实现这种事件顺序,但这是一般的想法。阻止UI从来就不是真正的意图,我认为jQuery包含该功能比删除它更困难。它意味着异步。
你为什么要用ajax来获取这个文件?只需使用
在任何情况下,您都不会将所有代码放在onSuccess中 - 而是从那里调用一个启动代码运行的函数。