我想用自定义服务中的数据来装饰角度$资源返回的数据。 我的代码是:
angular.module('yoApp')
.service('ServerStatus', ['$resource', 'ServerConfig', function($resource, ServerConfig) {
var mixinConfig = function(data, ServerConfig) {
for (var i = 0; i < data.servers.length; i++) {
var cfg = ServerConfig.get({server: data.servers[i].name});
if (cfg) {
data.servers[i].cfg = cfg;
}
}
return data;
};
return $resource('/service/server/:server', {server: '@server'}, {
query: {
method: 'GET',
isArray: true,
transformResponse: function(data, header) {
return mixinConfig(angular.fromJson(data), ServerConfig);
}
},
get: {
method: 'GET',
isArray: false,
transformResponse: function(data, header) {
var cfg = ServerConfig.get({server: 'localhost'});
return mixinConfig(angular.fromJson(data), ServerConfig);
}
}
});
}]);
看来我做的关于依赖注入一些错误。从ServerConfig.get()返回的数据被标记为未解析。 我得到了一个控制器,我做的改造与
ServerStatus.get(function(data) {$scope.mixinConfig(data);});
这个工作,但我宁愿做在服务的装饰。我该如何做这项工作?
'transformResponse'函数是否被调用?你使用的是什么版本的Angular?你会发现一个简约的例子在这里实现响应装饰:http://jsfiddle.net/YxTNL/1/ –
@LukasBünger感谢您的回复。我想出了一个解决方案,并将其发布到http://jsfiddle.net/maddin/7zgz6/ 我想在transformResponse中实现的是不可能的。我想我写了一个正确的答案... – Maddin