不推荐使用jQuery.ajax()方法的异步选项,现在怎么办?在jQuery 1.8中,使用async:false在jQuery.ajax()被弃用。但是,在后台正在进行的AJAX通信中,您在“加载屏幕”中看到了多少个网页?我可能已经看过数千个。我的情况是我正在编写一个需要加载语言文件的移动应用程序。在开始时,我加载语言文件,然后从语言文件中检索按钮和其他GUI元素的文本。这对我来说真的很糟糕。因为如果缺少语言文件,则不应出现GUI。那么我该如何解决呢?把我所有的代码都放在success回调中?这对我来说似乎不是一个好的编码实践。我可以用另一种方式解决吗?
3 回答
拉莫斯之舞
TA贡献1820条经验 获得超10个赞
解决方案是手动添加覆盖以防止用户与界面交互,然后在完成AJAX查询后将其删除。
$(function() { show_overlay(); $.ajax({ // Query to server }).done(function() { // Verify good data // Do stuff remove_overlay(); });});
千巷猫影
TA贡献1829条经验 获得超7个赞
我敢打赌,在等待AJAX调用时,这1000个页面中的许多页面实际上并没有阻止UI。相反,他们可能在调用时使用等待屏幕模糊UI,然后在响应处理程序上删除它。
隐藏UI的方法有很多种(你甚至可以使用设置为Modal的jQuery UI对话框,没有转义或关闭按钮),所以我会把这个决定留给你。但代码的布局将是这样的:
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 包含该功能比删除它更困难。它意味着异步。
- 3 回答
- 0 关注
- 868 浏览
添加回答
举报
0/150
提交
取消