0

我通过使用 Promises 下载 JSON 数据并将其存储在变量中来开始我的 Angular 控制器:

app.controller('mainController', ['$scope', '$http', '$q', function($scope, $http, $q) {
  var req1 = $http({method: 'GET', url: 'link to JSON 1', cache: 'true'});
  var req2 = $http({method: 'GET', url: 'link to JSON 2', cache: 'true'});

  $q.all([req1, req2]).then(function(response){
    var res1 = response[0].data;
    var res2 = response[1].data;

    $scope.data1 = res1;       // JSON which I will manipulate
    $scope.data1Ref = res1;   // JSON for reference which I won't manipulate

    $scope.data2 = res2;
    $scope.data2Ref = res2;

    init(); // do the stuff with the data
  });
}]);

然而,在init()完成之后,如果我检查$scope.data1并且$scope.data1Ref它们都已被修改,那就是它们被绑定在一起了。

为什么会发生这种情况?如何确保保留原始下载 JSON 的存储版本以供参考?

4

3 回答 3

0

这是因为在 JavaScript 中,对象是通过引用传递的。当您将 $scope.data1 和 $scope.data1Ref 设置为 res1 时,您将它们设置为对 res1 的引用

为了解决这个问题,您可以使用angular.copy对 res 对象进行深层复制。

$scope.res1Ref = angular.copy(res1);

于 2016-03-01T17:49:46.970 回答
0

当你对对象使用赋值时,你只是给变量一个对象的引用,而不是复制对象。在您的代码中$scope.data1$scope.data1Ref、 和res1都指向完全相同的对象实例。要创建新对象,您需要复制现有对象。

Angular 提供了两个可以复制对象的函数,一个创建浅拷贝,另一个创建深拷贝。浅拷贝复制原始字段,如果对象包含子对象,则原始和副本都指向同一个子对象实例。在深层副本中,任何子对象也会创建新副本。

angular.extend可用于创建浅拷贝,而用于创建angular.copy深拷贝。

于 2016-03-01T17:47:46.900 回答
0

在 AngularJS 中,复杂对象是通过引用传递的。您可以在此处找到更多信息:angular.copy() 和赋值 (=) 之间的区别

于 2016-03-01T17:58:37.483 回答