5

假设我像这样创建了一个工厂、服务或提供者对象

myApp.factory('myService', function() {
  return {
    counter: 0,
    increment: function() {
      console.log('counter: ' + (this.counter++))
    }
  };
});

假设我有一个依赖它的控制器

myApp.controller('myCtrl', function(myService) {
  $scope.incr = function() {
    myService.increment();
  };
}

我在 html 的不同部分应用了这个控制器

<div ng-controller="myCtrl">
  <button ng-click="increment()">increment</button>
</div>
...
<div ng-controller="myCtrl">
  <button ng-click="increment()">increment</button>
</div>

现在,当我单击每个按钮时,计数器是通用的,它会变为 0、1、2、3,...

如何编写我的工厂、服务或提供者,以便每个控制器获得服务对象的不同副本?

4

2 回答 2

5

由于工厂是单例的,因此您每次都需要在工厂中使用一种方法来创建服务。将您的服务更改为具有一个 create 方法,该方法返回执行递增的服务:

myApp.factory('myService', function() {
  return {
    create: function () {
      return { 
        counter: 0,
        increment: function() {
          console.log('counter: ' + (this.counter++));
        }
      };
    }
  };
});

myApp.controller('myCtrl', function($scope, myService) {
  var service = myService.create();
  $scope.incr = function() {
    service.increment();
  };
});

此外,控制器方法名称与视图中的名称不匹配:

<div ng-controller="myCtrl">
  <button ng-click="incr()">increment</button>
</div>
...
<div ng-controller="myCtrl">
  <button ng-click="incr()">increment</button>
</div>

Plunkr

于 2015-06-20T00:10:01.220 回答
0

只需将 .factory 更改为 .service,这将在您每次注入时提供一个唯一的范围。

这个答案更好地描述了这样做的原因:AngularJS: Service vs provider vs factory

于 2016-02-26T22:52:00.573 回答