从控制器中查看服务中的值

时间:2013-04-09 19:40:09

标签: angularjs

我创建了一个服务来隔离业务逻辑并将其注入需要信息的控制器。我想要最终做的是让控制器能够观察服务中的值,这样我就不必进行广播/通知或复杂的消息传递解决方案,以便通知所有控制器有关数据的更改。服务。

我创建了一个plnkr,展示了我正在尝试做的基本想法。

http://plnkr.co/edit/oL6AhHq2BBeGCLhAHX0K?p=preview

是否可以让控制器观察服务的价值?

1 个答案:

答案 0 :(得分:49)

你已经做得对了。即将服务推送到范围变量中,然后将服务作为范围变量的一部分进行观察。

以下是适合您的解决方案:

http://plnkr.co/edit/SgA0ztPVPxTkA0wfS1HU?p=preview

HTML

<!doctype html>
<html ng-app="plunker" >
<head>
  <meta charset="utf-8">
  <title>AngularJS Plunker</title>
  <script>document.write('<base href="' + document.location + '" />');</script>
  <link rel="stylesheet" href="style.css">
  <script src="http://code.angularjs.org/1.1.3/angular.js"></script>
  <script src="app.js"></script>
</head>
<body ng-controller="MainCtrl">
  <button ng-click="start()">Start Count</button>
  <button ng-click="stop()">Stop Count</button>
  ControllerData: {{controllerData}}
</body>
</html>

Javascript:

var app = angular.module('plunker', []);

app.service('myService', function($rootScope) {
  var data = 0;
  var id = 0;

  var increment = function() {
    data = data + 1;
    $rootScope.$apply();
    console.log("Incrementing data", data);
  };

  this.start = function() {
    id = setInterval(increment, 500) ;

  };

  this.stop = function() {
    clearInterval(id);
  };

  this.getData = function() { return data; };

}).controller('MainCtrl', function($scope, myService) {
  $scope.service = myService;
  $scope.controllerData = 0;

  $scope.start = function() {
    myService.start();
  };

  $scope.stop = function() {
    myService.stop();
  };

  $scope.$watch('service.getData()', function(newVal) {

    console.log("New Data", newVal);
    $scope.controllerData = newVal;
  });
});

以下是您错过的一些内容:

  1. $ scope。$ watch中的变量顺序错误。它(newVal,oldVal)而不是相反。
  2. 由于你正在使用setInterval,这是一个异步操作,你必须让angular知道事情发生了变化。这就是你需要$ rootScope。$ apply。
  3. 的原因
  4. 你不能看$函数,但你可以看看函数返回的是什么。