Angular js - show/hide loading gif every new route

前端 未结 2 1456
太阳男子
太阳男子 2020-12-24 13:18

I\'m trying to toggle (hide/show) a loading gif on every new route, so my logic would be:

  • routeChangeStart = show loading gif
  • routeChangeSuccess = hi
相关标签:
2条回答
  • 2020-12-24 14:13

    Short answer: the $rootScope.layout.loading changed as expected. But if the templates are loaded the browser has no time to make the changes visible.

    Long answer: if you put console.log outputs in your $on listeners you will see, that a $routeChangeStart event fires, the template is loaded and after that $routeChangeSuccess fires. Under the hood the following happens:

    • $routeChangeStart fires
    • $rootScope.layout.loading becomes true
    • the template gets loaded asynchronously
    • the DOM is updated
    • the browser renders the loading gif

    a little bit later (the xhr request returns)

    • the template was loaded
    • $routeChangeSuccess fires
    • $rootScope.layout.loading becomes false
    • the DOM is updated
    • the browser did no longer show the gif

    what happens if the tmeplates are cached: - $routeChangeStart fires - $rootScope.layout.loading becomes true - $routeChangeSuccess fires - $rootScope.layout.loading becomes false - the DOM is updated (but this is the same state as before)

    As you can see the browser can not render the new state because a script is running that is not interrupted to give the browser time to render the DOM. If the template is not yet loaded, the ajax requests stops the script execution and give's the browser time to render the DOM.

    How to fix this?

    You can use a timeout that give's the browser time to update the DOM:

    $rootScope.$on('$routeChangeSuccess', function () {
        console.log('$routeChangeSuccess');
        //hide loading gif
        $timeout(function(){
          $rootScope.layout.loading = false;
        }, 200);
    });
    

    Here is your plunkr with this solution: http://plnkr.co/edit/MkREo0Xpz5SUWg0lFCdu?p=preview

    0 讨论(0)
  • 2020-12-24 14:17

    ( A little too much to put in a comment )

    I set the code up and saw that the loading variable was not updated each time and was due to the template caching, I guess the 'RouteChange' is not triggered.

    Disabling the template caching will let your code run each time ..

    app.run(function($rootScope, $location, $anchorScroll, $routeParams,$templateCache) {
    
       $rootScope.$on('$viewContentLoaded', function() {
           $templateCache.removeAll();
        });
    
       ....
    
    0 讨论(0)
提交回复
热议问题