大佬教程收集整理的这篇文章主要介绍了AngularJS,$ http和transformResponse,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
为了使角度不将数据转换为对象,您需要覆盖默认$
httpProvIDer.defaults.transformResponse的行为。它实际上是一组变压器。您可以将其设置为空:$http.defaults.transformResponse
= [];
这是我用来将64位长整数转换为字符串的示例转换器:
function longsToStrings(responsE) {
//console.log("transforming response");
var numbers = /("[^"]*":\s*)(\d{15,})([,}])/g;
var newResponse = response.replace(numbers, "$1\"$2\"$3");
return newResponse;
}
要将转换器添加到默认列表,例如在JsON反序列化器之前,您可以执行以下操作:
$http.defaults.transformResponse.unshift(longsToStrings);
我在AngularJS的$ http上遇到了一个奇怪的行为,但并没有真正理解transformResponse的工作方式(文档对此有点儿淡淡)。
WebAssets.get = function () {
return $http.get('/api/webassets/list',{
transformResponse: [function (data,headersGetter) {
// not sure what to do here?!
return data;
}].concat($http.defaults.transformResponsE) // presume this isn't needed,added for clarity
}).then(function (responsE) {
return new WebAssets(response.data);
});
};
api返回一个对象数组:
[{"webasset_name": "...","application_id": "...","etc": "..."},... ]
但是,当transformResponse完成操作后,数据就变成了索引对象:
{"0":{"webasset_name":"...","application_id":"...","1":....}
我想保留原始数据结构(对象数组)。
以上是大佬教程为你收集整理的AngularJS,$ http和transformResponse全部内容,希望文章能够帮你解决AngularJS,$ http和transformResponse所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。