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 ビットの long int を文字列に変換するために使用したトランスフォーマーの例です。

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 に答える