Show Page Loading Spinner on Ajax Call in jQuery Mobile

后端 未结 8 1806
说谎
说谎 2020-11-29 23:42

I\'m using $.ajax() to populate a list in my mobile web app. What I\'d like to do is have the jQuery mobile loading spinner appears while this call is being performed and di

相关标签:
8条回答
  • 2020-11-30 00:17

    You should do $.mobile.showPageLoadingMsg() just before the ajax call, and $.mobile.hidePageLoadingMsg() in the success (or fail) block so it goes away once a result comes back.

    I've never used jQuery mobile, but it should operate the same as showing/hiding a regular ol' spinning image.

    0 讨论(0)
  • 2020-11-30 00:19
    $(document).ajaxSend(function() {
        $.mobile.loading( 'show');
    });
    $(document).ajaxComplete(function() {
        $.mobile.loading( 'hide');
    });
    
    0 讨论(0)
  • 2020-11-30 00:23

    The problem here is that the call to $.ajax() happens within the control flow of the event handler (the caller).

    A very simple way to decouple the ajax request from this control flow is to let setTimeout() invoke this function for you, like so:

    setTimeout(function(){$.ajax( ... )}, 1);
    

    You can then use the 'beforeSend' and 'complete' events of $.ajax() as stated before and be sure, that your spinner is showing up.

    0 讨论(0)
  • 2020-11-30 00:25

    A few people have asked about the workaround I ended up implementing, so I figured I'd share it. It's nothing particularly elegant or complicated, but it did seem to work. I haven't used the framework since the official 1.0 was released, so this may have been solved in the update. Essentially, I put the $.mobile.showPageLoadingMsg() call into the pageshow function, but wrapped it in an if clause that only fires the first time the page is shown:

    var mainloaded = false;
    
    $('#main').live('pageshow', function(event) {   //Workaround to show page loading on initial page load
        if(!mainloaded) {
        $.mobile.showPageLoadingMsg();
        }
    });
    
    $('#main').live('pagecreate', function(event) { 
        $.ajax({
            url: //url
            dataType: //datatype,
            headers: //headers
            success: function(data) {
                //
                //...loading stuff
                //
                $.mobile.hidePageLoadingMsg();
                mainloaded = true;
            }
            //
            //...handle error, etc.
            //
        });
    });
    
    0 讨论(0)
  • 2020-11-30 00:32

    Before JQM 1.2:

    $(document).ajaxStart(function() {
        $.mobile.showPageLoadingMsg();
    });
    
    $(document).ajaxStop(function() {
        $.mobile.hidePageLoadingMsg();
    });
    

    Since JQM 1.2:

    $(document).ajaxStart(function() {
        $.mobile.loading('show');
    });
    
    $(document).ajaxStop(function() {
        $.mobile.loading('hide');
    });
    

    http://api.jquerymobile.com/page-loading/

    0 讨论(0)
  • 2020-11-30 00:35

    Or, the simplest way is to put it globally as a separation of concern -

    Put below code into your master/layout view

       <script type="text/javascript">
    
        $(document).bind('mobileinit', function () {
            //Loader settings
            $.mobile.loader.prototype.options.text = "Loading..";
            $.mobile.loader.prototype.options.textVisible = true;
            $.mobile.loader.prototype.options.theme = "b";
            $.mobile.loader.prototype.options.textonly = false; 
        }); 
    
        $(document).on({
            ajaxSend: function () { $.mobile.showPageLoadingMsg(); },
            ajaxStart: function () { $.mobile.showPageLoadingMsg(); },
            ajaxStop: function () { $.mobile.hidePageLoadingMsg(); },
            ajaxError: function () { $.mobile.hidePageLoadingMsg(); }
        });
    
    </script> 
    

    Edit: Please use instead if you are targeting latest version of JQM (>1.2):

    • $.mobile.loading('show');
    • $.mobile.loading('hide');
    0 讨论(0)
提交回复
热议问题