Perché non riesco a guardare un oggetto in un servizio. Ho una variabile semplice che funziona, ma un oggetto non funzionerà. http://plnkr.co/edit/S4b2g3baS7dwQt3t8XEK?p=previewOggetto servizio orologio Angularjs
var app = angular.module('plunker', []);
app.service('test', ['$http', '$rootScope',
function ($http, $rootScope) {
var data = 0;
var obj = {
"data": 0
};
this.add = function(){
obj.data += 1;
console.log('data:', obj);
};
this.getData = function() { return obj; };
}]);
app.controller('TestController', ['$scope', '$rootScope', '$filter', 'test',
function($scope, $rootScope, $filter, test) {
//test controller
$scope.add = function(){
test.add();
};
$scope.test = test;
$scope.$watch('test.getData()', function(newVal){
console.log('data changes into: ', newVal)
});
}]);
possibile duplicato di [$ guardare un oggetto in angolare] (http://stackoverflow.com/questions/19455501/watch-an-object -in-angolare) – kvetis
Ti suggerisco di scrivere 'function() { return test.getData(); }, 'invece 'test.getData()'. In questo modo puoi evitare i bug, perché angular non convalida la definizione della stringa. –