0

私は php Tonic と AngularJS を使用しています。したがって、残りのリソースを呼び出す角度があります。残りのコードは次のようになります。

/**
 * @method GET
 */
public function getData(){
    $response = new Response();
    $response->code = Response::OK;
    $response->body = array("one","two");
    return $response;
}

バックエンドでは、コードは本文に配列を持つ Response オブジェクトを返します。angular から $resource サービスを使用してバックエンドを呼び出します。

return {

    getBackData : function(){

        var call = $resource('/table_animation_back/comunication');

        call.get(function(data){
            console.log(data);
        });

    }

}

console.log の結果は次のとおりです。

Resource {0: "A", 1: "r", 2: "r", 3: "a", 4: "y", $promise: d, $resolved: true}0: "A"1: "r"2: "r"3: "a"4: "y"$promise: d$resolved: true__proto__: Resource

私は使用しようとしました:

call.query(function(){...})

しかし、phpのResponseは配列ではなくオブジェクトなので、このようにjavascriptのエラーが出てしまいました。配列にアクセスできません。どこが間違っていますか?

4

2 に答える 2

1

クライアントに送信する前に、配列を JSON にシリアル化する必要があります。

public function getData(){
    $response = new Response();
    $response->code = Response::OK;
    // Encode the response:
    $response->body = json_encode(array("one","two"));
    return $response;
}
于 2015-11-01T15:05:32.520 に答える
0

クライアントに返す前にデータをエンコードするのを忘れたと思います。サーバー側では、次のようにする必要があります。

$response->body = json_encode(array("one","two"));
return $response;

$q.deferクライアントでは、この場合に使用する必要があると思います。例えば:

angular.module('YourApp').factory('Comunication', function($http, $q) {
    return {
        get: function(token){
            var deferred = $q.defer();
            var url = '/table_animation_back/comunication';
            $http({
                method: 'GET',
                url: url
            }).success(function(data) {
                deferred.resolve(data);
            }).error(deferred.reject);
            return deferred.promise;
        }
    };
});
于 2015-11-01T15:15:56.850 に答える