Подтвердить что ты не робот

Область действия не обновляется в представлении после того, как обещание разрешено

Несмотря на то, что для этого есть аналогичный вопрос, Данные не обновляются в представлении после того, как обещание будет разрешено, но я уже использую этот подход, и представление не является обновляется.

У меня есть factory:

'use strict';

myApp
.factory('Factory1', [ '$http','$q','$location', '$rootScope', 'Service', function($http, $q, $location, $rootScope, Service){

    return {

        checkSomething: function(data){

          var deferred = $q.defer();  //init promise

          Service.checkSomething(data,function(response){
                // This is a response from a get request from a service
                deferred.resolve(response);
          });

          return deferred.promise;
        }
    };
}]);

У меня есть контроллер:

'use strict';

myApp
.controller('MyCtrl', ['$rootScope', '$scope', '$location','Service', 'Factory1' function($rootScope, $scope, $location, Service, Factory1) {


    if(Service.someCheck() !== undefined)
    {
      // Setting the variable when view is loaded for the first time, but this shouldn't effect anything
      $scope.stringToDisplay = "Loaded";

    }


    $scope.clickMe = function(){
      Factory1.chechSomething($scope.inputData).then(function(response){
          $scope.stringToDisplay = response.someData; // The data here is actually being loaded!

      });
    };

}]);

И представление:

<div class="app " ng-controller="MyCtrl">    
    {{stringToDisplay}}    
    <button class="button" ng-click="clickMe()">Update display</button>    
</div>

Но данные не обновляются в представлении, когда я нажимаю кнопку "Обновить дисплей". Почему?

Несмотря на то, что $scope загружается данными

EDIT:

Hm, кажется, что я получаю сообщение об ошибке при попытке $scope.$apply(), и он говорит:

[$rootScope:inprog] $digest already in progress
4b9b3361

Ответ 1

Это может быть проблема цикла дайджеста. Вы можете попробовать:

...
$scope.stringToDisplay = response.someData;
$scope.$apply();
...

Для полноты, здесь является приятным завершением $scope.$apply.

Изменить: Я попытался воспроизвести ошибку в эту скрипту, но не может найти никаких проблем. Он работает безупречно без $scope.$apply. Я использую setTimeout для моделирования асинхронных операций, которые не должны запускать цикл дайджеста сами по себе.

Ответ 2

Попробуйте вместо этой функции

$scope.clickMe =$scope.$apply(function(){
      Factory1.chechSomething($scope.inputData).then(function(response){
          $scope.stringToDisplay = response.someData; // The data here is actually being loaded!

      });
    });