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

AngularJS $scope. $Watch on json object не работает внутри директивы

Мне не хватает чего-то очевидного здесь. В моей директиве у меня есть работающая двухсторонняя привязка данных, но я не могу использовать $scope. $Watch() для мониторинга изменений, которые могут возникнуть в объекте js объекта родительской директивы.

http://jsfiddle.net/Kzwu7/6/

Как вы можете видеть, когда я пытаюсь использовать $watch на attrs.dirModel, результирующее значение undefined, и ничего не отслеживается, хотя я изменяю объект после короткой задержки. Я также попытался использовать (и не использовать) истинный флаг в инструкции $watch.

HTML:

<script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.0.4/angular.min.js"></script>

<div ng-app="test" ng-controller="MainCtrl">
    <dir dir-model="model"></dir>
    <p>{{model.tbdTwoWayPropA}}</p>
</div>

<script type="text/ng-template" id="template">
    <div class="test-el">{{dirModel.tbdTwoWayPropB}}</div>
</script>

JS:

var app = angular.module('test', []);

app.controller("MainCtrl", [
    "$scope", "$timeout",
    function($scope, $timeout){
        $scope.model = {
            tbdTwoWayPropA: undefined,
            tbdTwoWayPropB: undefined,
            tbdTwoWayPropC: undefined
        }

        // TBD Ajax call
        $timeout(function(){

            // alert("Model updated, but $scope.$watch isn't seeing it.");

            $scope.model.tbdTwoWayPropA = 1;
            $scope.model.tbdTwoWayPropB = 30;
            $scope.model.tbdTwoWayPropC = [{ a: 1 },{ a: 2 },{ a: 3 }];

        }, 2000)
    }
]);

app.directive('dir', [
  "$timeout",
  function($timeout) {
      return {
          restrict: "E",
          controller: function($scope){
              $scope.modifyTwoWayBindings = function(){

                  // Two-way bind works
                  $scope.dirModel.tbdTwoWayPropA = 2;
              }

              $timeout(function(){
                  $scope.modifyTwoWayBindings();
              }, 4000);
          },
          scope: {
              dirModel: '='
          },
          template: $("#template").html(),
          replace: true,
          link: function($scope, element, attrs) { 

            $scope.$watch( attrs.dirModel, handleModelUpdate, true);

              // alert(attrs.dirModel);

              function handleModelUpdate(newModel, oldModel, $scope) {
                  alert('Trying to watch mutations on the parent js object: ' + newModel);
              }
          }
      }
}]);
4b9b3361

Ответ 1

Поскольку вы используете '=', у вас есть свойство локальной директивы scope dirModel. Просто $watch, который:

$scope.$watch('dirModel', handleModelUpdate, true);