Show progress circular during $http post?

后端 未结 7 1595
旧巷少年郎
旧巷少年郎 2021-02-08 15:56

What is the best way to use Angular Material\'s Progress circular component with a $http request?

I currently have the code like this below:

Progre

相关标签:
7条回答
  • I hope this code helps.

      var isLoadingShown = false;
    
      $scope.$watch(function() {
        return $http.pendingRequests.length;
      }, 
      function(newValue, oldValue) {
        console.log(newValue);
        if(newValue !== 0) {
          if(!isLoadingShown) {
            showLoading();         
          }
        }
        else hideLoading();
      });
    
      function showLoading(){
        isLoadingShown = true;   
        $mdDialog.show({
          template: '<md-dialog style="background-color:transparent;box-shadow:none;overflow: hidden !important;">' +
                      '<div layout="row" layout-sm="column" layout-align="center center" aria-label="wait">' +
                        '<md-progress-circular class="md-hue-2" md-diameter="50px"></md-progress-circular>' +
                      '</div>' +
                    '</md-dialog>',
          parent: angular.element(document.body),
          clickOutsideToClose:false,
          escapeToClose: false,
          fullscreen: false
        });
      }
    
      function hideLoading(){
        $mdDialog.cancel();
        isLoadingShown = false; 
      }
    
    0 讨论(0)
  • 2021-02-08 16:24

    If you want a version of md-progress-circular that also inhibits the screen and has a backdrop place the md-progress-circular inside an mdDialog like this:

         function showWait(){
              $mdDialog.show({
                controller: 'waitCtrl',
                template: '<md-dialog style="background-color:transparent;box-shadow:none">' +
                            '<div layout="row" layout-sm="column" layout-align="center center" aria-label="wait">' +
                                '<md-progress-circular md-mode="indeterminate" ></md-progress-circular>' +
                            '</div>' +
                         '</md-dialog>',
                parent: angular.element(document.body),
                clickOutsideToClose:false,
                fullscreen: false
              })
              .then(function(answer) {
    
              });
       }
    

    here is a plunker i created that shows how Plunker

    0 讨论(0)
  • 2021-02-08 16:25

    You should hook up to $httpProvider's events:

    angular.module('common')
      .config(['$httpProvider', function($httpProvider){
        $httpProvider.interceptors.push(['$rootScope', '$q', '$timeout',
          function($rootScope, $q, $timeout) {
            return {
              request: function(config) {
                $rootScope.posting = new Date().getTime();
                $rootScope.$broadcast('$postingStart', config.url);
                return $q.resolve(config);
              },
              response: function(response) {
                $rootScope.posting = false;
                $rootScope.$broadcast('$postingEnd', response.config.url);
                return $q.resolve(response);
              },
              responseError: function(response) {
                $rootScope.posting = false;
                $rootScope.$broadcast('$postingEnd', response.config.url);
                return $q.reject(response);
              }
            };
          }]);
      }])
    .run(['$mdDialog', '$rootScope', function($mdDialog, $rootScope){
      var showing = false;
    
      function showWait() {
        if(showing) return;
        $mdDialog.show({
          controller: 'waitCtrl',
          template: '<md-dialog id="plz_wait" style="background-color:transparent;box-shadow:none">' +
          '<div layout="row" layout-sm="column" layout-align="center center" aria-label="wait">' +
          '<md-progress-circular md-mode="indeterminate" ></md-progress-circular>' +
          '</div>' +
          '</md-dialog>',
          parent: angular.element(document.body),
          clickOutsideToClose: false,
          fullscreen: false
        })
          .then(function(answer) {
            showing = false;
          });
      }
    
    
      $rootScope.$on('$postingStart', function(event, url) {
        if (!$rootScope.postingStartTimer) {
          $rootScope.postingStartTimer = $timeout(function() {
            showWait()
          }, 250);
        }
      });
    
      $rootScope.$on('$postingEnd', function(event, url) {
        if ($rootScope.postingStartTimer && posts.length === 0) {
          $timeout.cancel($rootScope.postingStartTimer);
          $rootScope.postingStartTimer = false;
          if(!showing) return;
          $mdDialog.cancel();
        }
      });
    
    }])
    
    0 讨论(0)
  • 2021-02-08 16:27

    I don't think you need the value attribute here with determinate mode. Instead you should use indeterminate mode, then show and hide the progress indicator using ngShow.

    <md-progress-circular md-mode="indeterminate" ng-show="isLoading"></md-progress-circular>
    

    And in your JS

    $scope.isLoading = true;
    $http.get("/posts")
       .success(function (data) {
            $scope.isLoading = false;
       });
    
    0 讨论(0)
  • 2021-02-08 16:34

    All answers are right just add one more thing that $http request is asynchronous you should use like this

    $scope.$apply(function(){
    $scope.isLoading = false;
    });
    

    And as whole like this

    <md-progress-circular md-mode="indeterminate" ng-show="isLoading"></md-progress-circular>
    

    And in your JS

    $scope.isLoading = true;

    $http.get("/posts")
       .success(function (data) {
             $scope.$apply(function(){
               $scope.isLoading = false;
             });
       });
    

    Note:- Source of the answer is the accepted answer.

    0 讨论(0)
  • 2021-02-08 16:34

    If you want to watch the progress of post data use uploadEventHandlers

    There is an example.

    $http({
        method: 'POST',
        url: '/uploadToFtp',
        headers: {
            'Content-Type': undefined
        },
        eventHandlers: {
            progress: function(c) {
                //console.log('Progress -> ' + c);
                //console.log(c);
            }
        },
        uploadEventHandlers: {
            progress: function(e) {
                //console.log('UploadProgress -> ' + e);
                //console.log(e);
                _self.progressValue = (e.loaded / e.total) * 100.0;
            }
        },
        data: postData,
        transformRequest: angular.identity
    })
    .then(callBack,errorCallBack)
    .catch(errorCallBack);
    

    Show the progress circular like this

    <md-progress-circular ng-if="ctrl.progressValue > 0 && ctrl.progressValue < 100" md-mode="determinate" value="{{ctrl.progressValue}}"></md-progress-circular>
    
    0 讨论(0)
提交回复
热议问题