2013-04-21 17 views
6

Witam Mam następny problem:Kątowa: wywołanie funkcji z widoku

Moim zdaniem nazywam funkcję prepareDynamicData (itemMenu);

<div ng-repeat="itemMenu in menuDetailsData.categories" class="headDetails fontH2"> 
      <div style="display: none">{{prepareDynamicData(itemMenu)}}</div> 
      <a href="#" ng-show="dynamicData.expand">{{itemMenu.name}}</a> 
      <div ng-repeat="cat in dynamicData.data"> 
       <p>{{cat.name}}</p> 
       <div class="articles"> 
        <div ng-repeat="art in cat.items" class="article"> 
         <div class="price"> 
          <div></div> 
          <span><i>₪</i>{{art.price}}</span> 
         </div> 
         <div class="artDescr"> 
          <span class="fontTitle">{{art.title}}</span> 
          <p class="fontDetails">{{art.description}}</p> 
         </div> 
        </div> 
       </div> 
      </div> 
     </div> 

wiem, że górna pętla repeting tylko 2 razy (zweryfikowane tego), ale funkcja prepareDynamicData (itemMenu) wywołanie 4 razy, nie wiem dlaczego !? Tu jest mój kontroler:

function MenuItemCtrl($scope, $routeParams, $http, $location, sharedData) { 
if (sharedData.getMenuDetails() == null) { 
    $location.path('/menu'); 
    return; 
} 
else { 
    $scope.menu = sharedData.getMenu(); 
    $scope.menuDetailsData = sharedData.getMenuDetailsData($routeParams.itemId); 
} 

$scope.dynamicData = { 
    data : new Array(), 
    expand : false 
}; 

$scope.prepareDynamicData = function (itemMenu) { 
    if (itemMenu.items != null) { 
     $scope.dynamicData.data[0] = itemMenu; 
     $scope.dynamicData.expand = false; 
    } 
    else { 
     $scope.dynamicData.data = itemMenu.categories; 
     $scope.dynamicData.expand = true; 
    } 
} 

}

Pomożesz mi wyjaśnić, dlaczego tak się dzieje! dzięki

Odpowiedz

9

AngularJS używa brudnego śledzenia, aby upewnić się, że widok pozostaje aktualny. Oznacza to, że AngularJS oceni wartości wiązań twojego widoku, dopóki się nie ustabilizują; w ten sposób będzie to robić co najmniej dwa razy na każde powiązanie w dowolnym momencie, gdy aktualizacje skojarzonego powiązania zostaną wykonane. (Na przykład, jeśli określony element wewnątrz pętli został zmieniony, prawdopodobnie zostałby wykonany jeszcze dwa razy.) Dlatego należy zadbać o to, aby funkcje powiązane w widoku nie wywoływały skutków ubocznych i działały szybko.

Generalnie, przenoszenie zadań przygotowywania danych do kodu uruchamianego podczas ładowania kontrolera lub do usługi wywoływanej ze sterownika jest dobrą praktyką - widok związany z tym kodem rzadko powinien wywoływać efekty uboczne! Jednakże, jeśli musisz/naprawdę chcesz wywołać taką funkcję z widoku, po prostu śledź, czy funkcja została już wywołana dla danego elementu.

Tutaj jest trochę additional reading on dirty tracking in Angular if you're interested.