1

我试图理解如何修改$resource.query()返回的数据 - 结果证明 - 不是真正的 Promise ,$q而是在异步调用完成时要填充的空对象/数组。

我定义了一个服务,我想修改来自的数据$resource(过滤它是精确的),但实际上没有过滤。我得到了整个数组。

我敢肯定我在这里遗漏了一些琐碎的事情。提前感谢您的帮助。

这是服务(员工是$resource):

  factory('Report', ['Employee',
        function(Employee) {

            var query = function(id, cb) {
                return Employee.query({}, function(data) {
                    return cb(data, id);
                });
            };

            var findByManager = function(employees, employeeId) {
                return employees.filter(function(element) {
                    console.log(element);
                    return employeeId === element.managerId;
                });

            };

            return {
                query: function(employee) {
                    return query(employee.employeeId, findByManager);
                }
            }; 
        }
  ]);

编辑

通过 ippi 的建议,我还尝试访问潜在的承诺:

var query = function(id) {
            return Employee.query().$promise
                .then(function(data) {
                    return findByManager(data, id);
                });
        };

return {
    query: query,
}

在控制器中:

$scope.employees = Report.query(id);

但它返回对象而不是数组。

4

1 回答 1

1

我不确定这是否是您正在寻找的完整答案,但它应该会有所帮助:

Employee.query({...}) 本身不是一个承诺,但您可以像这样访问原始的 $http 承诺:

Employee.query({...}).$promise.then(function(result){
    console.log(result);
});

($resource 只是 $http 的包装。)

如果您不介意我这么说,那么在您检索资源的那一刻就在客户端过滤资源的想法听起来确实与 API 资源的想法背道而驰。请求“员工”的一个子集听起来确实像一个 API 功能,并且可能应该在服务器端实现。我会说你想调用你的资源:

Employee.query({ managerId: employee.employeeId });

编辑:

好吧,我报废了你的Report工厂(对不起!)并最终得到:

// Controller
$scope.id = 1; // Or something...
$scope.employees = Employee.query();

// Html
<tr ng-repeat="employee in employees | filter: {employeeId: id} : true | orderBy:id">

这似乎也是一个可以接受的答案:https ://stackoverflow.com/a/28907040/1497533

于 2016-05-09T08:25:18.667 回答