3

我有一个控制器,它显示一个清单,并将选择存储在一个数组中。

我的另一个控制器$http.get从第一个控制器在阵列上运行。

如何设置一个$watch,以便每当数组更改时,都会发送一个新的 HTTP GET 请求?

我的尝试: http: //plnkr.co/edit/EaCbnKrBQdEe4Nhppdfa

// See plnkr for other controller + FooSelection factory + view
function SimpleQueryResCtrl($scope, $http, FooSelection) {
    $scope.foo_list_selection = FooSelection;

    $scope.$watch('foo_list_selection', function (newValue, oldValue) {
        if (newValue !== oldValue)
            $http.get('/api/' + $scope.foo_list_selection).success(function (largeLoad) {
                $scope.myData = largeLoad;
            });
    });
}

SimpleQueryResCtrl.$inject = ['$scope', '$http', 'FooSelection'];
4

3 回答 3

3

默认情况下, a$watch检查引用的更改,而不是相等性。由于对象和数组在修改时仍然具有相同的引用,因此不会触发监视。至少有两个选项可以让它工作。

如果您想要通知的唯一更改是修改数组的大小(添加或删除元素与更改元素的内容),您可以在数组的长度属性上设置监视,而不是像:

$scope.$watch('foo_list_selection.length', function (newValue, oldValue) {
// ...

否则,您可以使用可选$watch参数objectEquality,它需要一个布尔值。这会进行相等性检查而不是参考检查。

$scope.$watch('foo_list_selection', function (newValue, oldValue) {
    if (newValue !== oldValue)
        $http.get('/api/' + $scope.foo_list_selection).success(function (largeLoad) {
        $scope.myData = largeLoad;
    });
}, true);  // <- put `true` here

这不是默认行为,因为它对所有元素执行更昂贵的深度检查,因此仅在必要时使用。

于 2013-06-02T17:30:22.270 回答
1

将其中一些逻辑移入工厂,然后将其发送给所有控制器,$rootScope.$broadcast并将您的信息发送到正确的位置。

我将数组创建移到工厂中,然后从那里使用 $broadcast :

myApp.factory('FooSelection', function ($rootScope) {
var tempArr = [];
var fixArray = function(item){
  if (tempArr.indexOf(item) === -1){
    tempArr.push(item);
  } else {
    tempArr.splice(tempArr.lastIndexOf(item), 1);
  }
  $rootScope.$broadcast('newArray', tempArr);

}

return {fixArray: fixArray}
})

在控制器中使用$scope.$on在更改时接收新数据:

function SimpleQueryResCtrl($scope, $http, FooSelection) {
$scope.foo_list_selection = FooSelection;

$scope.$on('newArray', function(evt, message){
  console.log(message) // and you can put your $get method here
})
}

这是笨拙的

于 2013-06-02T18:36:22.070 回答
0

在这种情况下,我建议使用数据操作和消息服务来保持控制器和 UI 同步。

看这里:AngularJS 对 Controller 和 rootScope 的多次使用

于 2013-06-03T06:27:12.307 回答