2016-12-19 10 views
0

Я использую toaser, чтобы сообщить пользователю, что файл был успешно загружен. Проблема в том, что тостер показывает сообщение дважды.AngularJS toaster показывает предупреждение дважды, а не один раз при загрузке файла

Части моего HTML код:

<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script> 
<script src="https://cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.8/angular-resource.min.js"></script> 
<script src="http://code.angularjs.org/1.4.8/angular-animate.min.js" ></script> 
<script src="../common/toaster.js"></script> 
<script src="../common/ng-file-upload.min.js"></script> 
<script src="../common/ng-file-upload-shim.min.js"></script> 
<script src="../common/angular-sanitize.min.js"></script> 
<script src="messages.controller.js"></script> 
<script src="../common/cookieGet.js"></script> 
... 
<table class="sendFile" ng-show="hiddenFriendId != null" style="overflow-y: auto; overflow-x: hidden; height:100px; width:100%;"> 
      <tbody> 
       <tr> 
        <td style="vertical-align: top;"> 
         <div 
         width = "100%" 
         ngf-select="" 
         ngf-drop="" 
         ng-model="files" 
         class="drop-box" 
         ngf-drag-over-class="{ accept:'dragover', reject:'dragover-err', delay:100}" 
         ngf-multiple="true" ngf-allow-dir="false" 
         ngf-max-size="10MB" ngf-max-files="10" 
         accept="image/*,application/pdf" 
         ngf-pattern="'image/*,application/pdf'"> 
          Click here <b>OR</b> drag&drop pdfs or images 
         </div> 
         <div ngf-no-file-drop>File Drag/Drop is not supported for this browser</div> 

         <div ng-show="files.length>0"> 
          <div ng-repeat="f in files"> 
           <progressbar ng-show = "f.progressPercentage > 100"> 
            <bar style="width:{{f.progressPercentage}}%;"> 
             Upload: {{f.name | limitTo:50 }} {{f.$error}} {{f.$errorParam}} - {{ f.progressPercentage }}% completed 
            </bar> 
           </progressbar> 
          </div> 
         </div> 
        </td> 
       </tr> 
      </tbody> 
     </table> 

А вот мой JS часть для загрузки файла:

$scope.upload = function (files) { 
    var urlUploadFile = "http://localhost:8180/ChatRestNoSQLMaven/rest/MessageService/upload/"; 
    var progressPercentage = 0; 
    if (files && files.length) { 
     for (var i=0; i < files.length; i++) { 
      var file = files[i]; 
      if (!file.$error) { 
      Upload.upload({ 
       url: urlUploadFile, 
       data: { 
        securityKey: securityKey, 
        friendId: $scope.hiddenFriendId, 
        file: file 
       } 
      }).then(function (resp) { 
       $timeout(function() { 
       }); 
      }, function (response) { 
       if (response.status > 0) { 
        $scope.errorMsg = response.status + ': ' + response.data; 
        toaster.pop("error","Error","Unable to upload file. Please try again..."); 
       } 
      }, function (evt) { 
       var loaded = evt.loaded; 
       var total = evt.total; 
       var number = 100.0 * (evt.loaded/evt.total); 
       if (number == 100){ 
        toaster.pop("success","File uploaded","File " + file.name + " successfully uploaded"); 
       } 
       file.progressPercentage = number.toFixed(); 
      }); 
      } 
     } 
    } 
} 

Так, может кто-нибудь помочь мне, чтобы избежать этой проблемы и бросить только предупреждение toaser один раз. Спасибо!

ответ

1

Из раздела Javascript code под номером https://github.com/danialfarid/ng-file-upload/blob/master/README.md#-usage вы можете видеть, что обратный вызов THIRD в блоке Upload.upload().then(...) используется для обновления индикатора выполнения. Это не гарантируется для запуска только один раз.

Вместо этого попробуйте ввести код тостера в FIRST обратном вызове, где в настоящее время у вас есть $timeout(...), чтобы помочь выделить проблему.

+0

} ОК, спасибо, постараемся дать вам знать. –

+0

проблема решена, спасибо –

0

Если вы это сделаете, браузер выполнит дважды запрос: первый раз - запрос OPTION, второй раз - это настоящий запрос POST. Проверьте его в сети devtools браузера, чтобы убедитесь, что многие запрашивают браузер.

+0

Да, когда я его отлаживаю - он работал дважды, поэтому этот раздел определенно не соответствует моей задаче. Попробуем сделать это - .then (function (resp) { $ timeout (function() { }); –