11

我在使用 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":"...", "etc": "..."}, "1":....}

我想保留原始数据结构(对象数组)。

4

3 回答 3

14

要使角度不将数据转换为对象,您需要覆盖默认 $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);
于 2013-09-02T23:57:51.067 回答
3

资源 0:“f”1:“a”2:“l”3:“s”4:“e”这终于对我有用:

   transformResponse: function (data, headersGetter) {
    return { isCorrect: angular.fromJson(data) }
    }
于 2015-05-26T19:34:22.743 回答
1

尝试使用资源查询方法

https://github.com/angular/angular.js/issues/6314

于 2015-07-03T14:30:07.810 回答