我定义了一个已定义自定义方法的资源。 在我的模板中,我无法使用此方法。 我的代码看起来像这样。未调用getName()函数。我在这里想念的是什么
personservices.factory("Person", ["$resource", function($resource) {
var Persons = $resource("", {}, {
query: {method:'GET'}
});
Persons.prototype.getName = function () {
/* do something */
return name;
}
return Persons;
}]);
<ul>
<li ng-repeat="person in persons">
{{ person.getName() }} -> not being called
{{ person.id }}
</li>
</ul>
$scope.Persons = Person.query()
- &gt;完美地运作
答案 0 :(得分:3)
你的问题是:
您需要一个人员列表,但您返回的数据不是列表。因此,您可以在服务中使用transformResponse
将对象转换为数组。
功能getName
应该返回this.name
,而不是name
。
app.factory("Persons", ["$resource", function($resource) {
var Persons = $resource("", {}, {
query: {
method:'GET',
isArray: true,
transformResponse: function(data, header) {
return angular.fromJson(data).items;
}
}
});
Persons.prototype.getName = function () {
/* do something */
return this.name;
}
return Persons;
}]);
这是一个JSFiddle示例:http://jsfiddle.net/9JFhA/1/
答案 1 :(得分:0)
您的示例服务几乎完美定义,我所做的唯一更改是我向您的自定义isArray: true
函数添加了query
,因为它返回了一个人员列表。
var Persons = $resource("/person", {}, {
query: {method:'GET', isArray: true}
});
也许这就是为什么你的自定义方法没有被调用。
看看我制作的工作的plunker:http://plnkr.co/edit/2i7IHs?p=preview,它在$ resource服务中测试自定义方法的功能。