私は、外部ソースからデータを取得しているファクトリを持っています。データを取得するとすぐに、私は第2工場を使用して特定の基準でフィルタリングします。
このプロパティはスコープに割り当てられています。
今、私は私の工場でこれを行うとき、それはスコープを更新しません:
factory.foo = [{id:1,name:'foo'}]; // doesn't work
そのためにも、この作品つつ、第2工場でfilterinが
factory.foo = Filter.filter(); // doesn't work
を動作しません。 :
factory.foo.push({id:1,name:'foo'}); // works
これが意図されている理由は誰か、どのように解決するのですか?
app.factory('Foo',function(Filter) {
var factory = {
foo:[],
getDataForFoo:function() {
factory.foo = Filter.filter(); // doesn't work
//factory.foo = [{id:1,name:'foo'},{id:1,name:'foo'}]; // doesn't work
//factory.foo.push({id:1,name:'foo'}); // works
}
};
return factory;
});
app.factory('Filter',function() {
var factory = {
filter:function() {
var arr = [];
arr.push({id:1,name:'foo'});
return arr;
}
}
return factory;
});
app.controller('MainCtrl', function($scope,Foo) {
$scope.test = 'running';
$scope.foo = Foo.foo;
$scope.click = Foo.getDataForFoo;
});
Simon Belangerの言葉通りです。私はここで説明します:http://angular-tips.com/blog/2013/08/consuming-services/ –
スコープ継承の詳細については、この回答を参照してください。http://stackoverflow.com/questions/14049480/what-スコーププロトタイプのprototypal継承in-angularjs – piatek
@piatek私はスコープの継承に関連しているとは思わない。 –