27

私は SO と Google を隅々まで調べましたが、それが役に立ったことに気づきました。続行する方法がわかりません。次のような配列を使用してphpページから返す配列がありますecho json_encode()

[" "," "," "," "," ",1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31]

しかし、Unexpected token o at Object.parse (native)JSON.parse() を使用しようとするとUnexpected token o at Function.parse (native)、JQuery の代替手段を使用すると取得し続けます。

しかし、それを添付するだけ$scopeで、ページで使用して印刷できるので、何が間違っているのですか?どうすれば修正できますか?

これは私のコントローラーです

function myController($scope, memberFactory) {

    response = memberFactory.getMonth("2013-08-01 06:30:00");
    //$scope.response = response;
    var monthDays = $.parseJSON(response);

    var dates = [];
    for (var i = 0; i < monthDays.length; i++) {
        if (i % 7 == 0) dates.push([]);
        dates[dates.length - 1].push(monthDays[i]);
    }
    $scope.dates = dates;
    //
}

これは私のサービス方法です:

obj.getMonth = function (date) {
    var month = $q.defer();
    $http.get('getMonth.php?date=' + date)
        .success(function (data, status, headers, config) {
        month.resolve(data);

    });

    return month.promise;
}

これは私のphpです:

<?php $daysOfMonth=[ " ", " ", " ", " ", " ",1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31];
echo json_encode($daysOfMonth); ?>

私が試したこと

typeofI get Objectを返すvar monthDays = Array.prototype.slice.call(response)と、試してみましたが、ここvar monthDays = $.map(response, function (value, key) { return value; });の回答のいくつかで示唆されているように、私も試しましたが、結果として得られますJSON.stringify(){}

私はこれに本当にイライラしており、誰かが私を正しい方向に向ける必要があります

アップデート

$q.defer()getMonth メソッドを次のように更新したため、これは使用に問題がある可能性があると思います。

obj.getMonth = function (date) {
    var month = $q.defer();
    $http.get('getMonth.php?date=' + date)
        .success(function (data, status, headers, config) {
        month.resolve(data);
        console.log("data " + data[0]);
        console.log("resolved " + month.promise[0]);

    });

    return month.promise;
}   

今、私は期待どおりに取得しますが1、取得しますconsole.log("data " + data[0]);console.log(month);[object Object]console.log(month.promise)[object Object]console.log(month.promise[0]);undefined

4

4 に答える 4

65

responseすでに解析されているため、再度解析する必要はありません。

再度解析すると、最初に toString-cast が実行されるため、解析しています

"[object Object]"

を説明しunexpected token oます。

于 2013-08-08T15:32:55.633 に答える
6

$httpモジュールのリクエストとレスポンスの変換の章を見てください。

JSON 応答が検出された場合は、JSON パーサーを使用して逆シリアル化します。

既に JSON オブジェクトとして解析されているため、再度解析するとそのエラーが発生します。

簡単なテストを次に示します。

response = '{"a": "a","b": "b"}';
var obj = $.parseJSON(response);
console.log(obj); //Object {a: "a", b: "b"} 
$.parseJSON(obj)  //Uncaught SyntaxError: Unexpected token o 
于 2013-08-08T15:37:52.030 に答える