AngularJS:$resource未调用自定义方法
AngularJS: $resource custom methods not being called
>我定义了一个资源,我已经为其定义了自定义方法。在我的模板中,我无法点击此方法。我的代码如下所示。未调用 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()
->完美运行
你的问题是:
-
您需要人员列表,但返回的数据不是列表。因此,您可以在服务中使用
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/
您的示例服务几乎完美地定义,我所做的唯一更改是我为您的自定义query
函数添加了一个isArray: true
,因为它返回人员列表。
var Persons = $resource("/person", {}, {
query: {method:'GET', isArray: true}
});
也许这就是未调用自定义方法的原因。
看看我制作的 plunker 工作 plunker:http://plnkr.co/edit/2i7IHs?p=preview,它在 $resource 服务中测试自定义方法的功能。
相关文章:
- 用于检查数组中是否存在元素的javascript自定义方法
- Es6:能够在设置/更新/删除对象属性时调用自定义方法
- 如何用Typescript用自定义方法实现类数组
- $resource上带有.then()函数的角度自定义方法导致错误
- 如何将原型用于自定义方法和对象操作
- 在javascript中调用自定义谷歌搜索标签时出现问题
- 续集返回未定义的模型自定义方法
- jQuery 在自定义方法中使用 if 语句进行验证
- AngularJS:$resource未调用自定义方法
- 调用自定义API方法的功能
- 无法在主干模型上调用自定义方法
- 在浏览器关闭时,JavaScript并不总是调用自定义的服务器端方法(Asp.Net/C#)
- 是否有一种方法可以在调用对象的未定义函数时调用自定义函数?
- 如何调用自定义get方法
- 如何在聚合物1.0中调用元素的自定义方法
- 如何从angular js中的自定义服务中调用自定义指令中的方法
- 使用angularjs $resource从web api调用自定义方法
- 从自定义方法调用客户端事件
- 在 DOM 元素上调用自定义方法
- 调用自定义jquery方法