【发布时间】:2016-05-08 01:55:06
【问题描述】:
我想修改(过滤)角度服务中的数组(我通过 ngResource 获得的数据),然后将修改后的数据传递给控制器,但由于它的异步行为,我被卡住了。
代码如下:
(function() {
'use strict';
angular.module('app').factory('Report', ['Employee', function(Employee) {
var getReports = function(employeeId) {
return Employee.query({}, function(employees) {
return employees.filter(function(element) {
return employeeId === element.managerId;
});
});
};
return {
query: function(employee) {
return getReports(parseInt(employee.employeeId));
}
};
}]);
}());
我在控制器中这样调用它:
$scope.employees = Report.query({employeeId: $routeParams.employeeId});
上面的代码有两个问题:
- 它不起作用 :) getReports() 返回整个员工数组,不进行过滤,
- 它看起来不像优雅或可维护的设计。在这方面我可以改进什么?
【问题讨论】:
标签: angularjs angular-resource