How to hold page render until an AJAX call completes?

前端 未结 3 1196
梦毁少年i
梦毁少年i 2021-01-18 13:52

I know that the huge advantage of doing AJAX calls is that the rest of the page can load and be ready for the user before a certain element is quite ready yet. But I have a

相关标签:
3条回答
  • 2021-01-18 14:19

    Update 03/2015: I would strongly advise against using this method, since synchronous XMLHttpRequests on the main thread are now deprecated; see http://xhr.spec.whatwg.org/

    Synchronous XMLHttpRequest outside of workers is in the process of being removed from the web platform as it has detrimental effects to the end user's experience. (This is a long process that takes many years.) Developers must not pass false for the async argument when the JavaScript global environment is a document environment. User agents are strongly encouraged to warn about such usage in developer tools and may experiment with throwing an InvalidAccessError exception when it occurs.


    jQuery.ajax() sports an async parameter. When set to false, your AJAX request becomes synchronous / blocking.

    As for the page load: Do not hook into any "ready" event. Just call directly after loading the jQuery library:

    $('body').css('display', 'none');
    

    Then run your (now synchronous) AJAX request.

    On AJAX completion/success, Do

    $('body').css('display', 'block');
    

    Cheers.

    0 讨论(0)
  • 2021-01-18 14:22

    You can set the display of your wrapper element to none and then change it to block after the ajax request returns.

    0 讨论(0)
  • 2021-01-18 14:34

    try using async:false in your ajax call.

    0 讨论(0)
提交回复
热议问题