Ajax 加载完成后 jQuery 执行加载消息!

发布于 2024-10-27 09:13:08 字数 1628 浏览 3 评论 0原文

这似乎让我发疯。

我尝试在进行 ajax 调用之前显示 ajax 加载器 gif。 Firefox 是唯一一个能够按顺序执行此操作的浏览器。所有其他浏览器都会先完成 ajax 调用,然后显示加载程序。

这是代码:

$(#element).click(function(evt){

  tmp_eleX = $this.offset().left;  // get current left position of element 
  tmp_eleY = $this.offset().top;   // get current top position of element  

  $('#ajax_loader').css({top: tmp_eleY-208}); // show ajax loader which was placed outside viewable area (-9999)

  $.ajax({
    url: "some_file.cfm",
    cache: false,
    dataType: "html",
    async: false, // wait for loading to finish before continuing code
    timeout: 30000,
    error: function(){
      return true;
    },
    success: function(data) {
      $('#someelementtoinject_ajaxdata').html(data);
    }
  });                        

  $('#ajax_loader').css({top: -9999}); // move ajax loader off screen - for testing i comment out this line to see when the loader shows!

});

这让我抓狂。我尝试在所有浏览器中的 ajax 调用之前将 Ajax 调用包装在

window.setTimeout(function(){
}, 0);

Ajax 加载器显示中,问题是动画 GIF 在 ajax 完成加载内容之前不会进行动画处理!

我也尝试过:

  $('#ajax_loader')
    .ajaxStart( function() {
      $(this).css({
        top: -208
      })
    })
    .ajaxStop(function(){
      $(this).css({
        top: -1000                          
      })
    });

相同的结果 Ajax 在 .ajaxStart 触发之前完成,哎呀:/!在这里,只有 Firefox 可以正常工作并在 ajax 调用之前显示动画。

它似乎在所有浏览器中工作的唯一方法是设置 ajax 调用“async: true”。在继续之前完全加载 ajax 并可能触发页面上的另一个 ajax 调用对于 ajax 来说是至关重要的。

关于如何在ajax完成之前触发加载程序的任何想法?另外,ajax 需要在代码继续之前完成。

我没想到这个@^&^#@我的大脑在流血:/

This seems to drive me batty.

I try showing an ajax loader gif before making the ajax call. Firefox is the only browser that seems to do this in order. All other browser finish the ajax call first and then show the loader.

this the code:

$(#element).click(function(evt){

  tmp_eleX = $this.offset().left;  // get current left position of element 
  tmp_eleY = $this.offset().top;   // get current top position of element  

  $('#ajax_loader').css({top: tmp_eleY-208}); // show ajax loader which was placed outside viewable area (-9999)

  $.ajax({
    url: "some_file.cfm",
    cache: false,
    dataType: "html",
    async: false, // wait for loading to finish before continuing code
    timeout: 30000,
    error: function(){
      return true;
    },
    success: function(data) {
      $('#someelementtoinject_ajaxdata').html(data);
    }
  });                        

  $('#ajax_loader').css({top: -9999}); // move ajax loader off screen - for testing i comment out this line to see when the loader shows!

});

This is driving me batty. I tried wrapping the Ajax call in

window.setTimeout(function(){
}, 0);

The Ajax Loader show before the ajax call in all browser, PROBLEM the animated GIF is NOT ANIMATING until ajax finished loading stuff!

I also tried:

  $('#ajax_loader')
    .ajaxStart( function() {
      $(this).css({
        top: -208
      })
    })
    .ajaxStop(function(){
      $(this).css({
        top: -1000                          
      })
    });

Same result Ajax finished before .ajaxStart triggers, heck :/! Here too, only Firefox works properly and shows animation before ajax call.

the only way it seems to work in all browser is setting the ajax call 'async: true'. It is kinda vital for the ajax to load completely before continuing and possibly trigger another ajax call on the page.

Any Idea on how I can trigger the loader before the before ajax completes its thing? Also the ajax needs to be finished before code continues.

I didn't expect this @^&^#@ my brain is bleeding :/

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

清泪尽 2024-11-03 09:13:08
async: false, // wait for loading to finish before continuing code

这似乎是你的问题 - 你没有异步进行 AJAX 调用,因此(我猜),控制权不会返回到浏览器,因此它无法响应“显示 gif”操作,直到AJX 调用返回后。

async: false, // wait for loading to finish before continuing code

That would appear to be your problem - you aren't making the AJAX call asynchronously, therefore (I'd guess), control isn't returning to the browser, so it can't respond to the 'show the gif' action until after the AJX call returns.

画尸师 2024-11-03 09:13:08

感谢您的快速回答...

我通过添加一个全局变量解决了问题,这也使其成为放置 async: true 的选项。我将全局标志设置为 ajax 调用的成功函数中的最后一个操作。

Thanks for the quick answers ...

I solved the problem by adding a global variable which also made it an option to put async: true. I set the global flag as last action within the success function of the ajax call.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文