6

一个孩子$scope(无论是否孤立)是否可以在$scope.$apply没有应用父范围的情况下这样做?

在父作用域中有一些昂贵的计算(很难缓存),我不需要角度来重新运行计算。

例如:

<div ng-controller="ParentController"> 
{{ expensiveFunction() }}
  <div directive>
    <h1 ng-click="applyChildScopeOnly()">Click {{ value }}</h1>
  </div>
  <div directive>
    <h1 ng-click="applyChildScopeOnly()">Click {{ value }}</h1>
  </div>
<button ng-click="applyChildrenScope()"/> <!-- apply to children scope only -->
</div>

指令:

module.directive('directive', ['$document','$rootScope', function ($document,$rootScope) {

  return{
    restrict:'AE',
    scope:{},
    link:function($scope, element, attrs){
        $scope.applyChildScopeOnly = function(){
           $scope.$apply(); // don't apply changes to $parent scope
        };

    }
  }
}]);
4

1 回答 1

7

您可以调用$scope.$digest()而不是$scope.$apply()重新评估当前范围及其所有子范围内的手表。调用$scope.$digest()不会评估任何父作用域上的任何手表。

作为旁注,幕后$scope.$apply()调用。$rootScope.$digest()

更多信息在这里:http ://docs.angularjs.org/api/ng .$rootScope.Scope

于 2013-04-08T15:39:21.890 回答