0

helloは、ループの外側にある関数を呼び出して、IDの2つの場所を配列に保存しようとしています。問題は、locが関数ではないというエラーが表示されることです。誰かが問題がどこにあるか知っていますか?

var geocoder;
var map, x, y;
var loc = [];
geocoder = new google.maps.Geocoder();
//    var address = document.getElementById("address").value;
//  var user='33936357';
$.getJSON("http://api.twitter.com/1/users/lookup.json?user_id=33936357,606020001&callback=?", function (data) {
    $.each(data, function (i, item) {
        var screen_name = item.screen_name;
        var img = item.profile_image_url;
        var location = item.location;
        geocoder.geocode({
            address: location
        }, function (response, status) {
            if (status == google.maps.GeocoderStatus.OK) {
                var x = response[0].geometry.location.lat(),
                    y = response[0].geometry.location.lng();
                loc(x, y);

            } else {
                alert("Geocode was not successful for the following reason: " + status);
            }
        }); //GEOCODER.GEOCODE
    });

    function loc(x, y) {
        loc.push({
            latitude: x,
            longitude: y
        });
    }
    console.log(loc); //$.EACH
}); //.GETJSON
} //CODEADDRESS
4

3 に答える 3

0

コールバック関数内で$.each()、ローカル変数を作成します。

var location = item.location;

...これは。の外部location()宣言された関数と同じ名前です。名前を再利用することにより、内部変数は外部関数を「マスク」します。$.each()

そのため、そのコールバックのスコープ内で関数locationではないローカル変数を参照しているため、関数ではないというエラーが発生します。

変数または関数の名前を変更するだけです。

于 2012-08-09T10:43:34.487 に答える
0

。という名前の配列を宣言しましたloc。配列変数に別の名前を使用するか、関数名を変更してください。

あなたの問題は以下のようなものです:

​var foo = [];
function foo() {
  foo.push(1);    
}
foo(); // here foo is the array []
于 2012-08-09T10:30:20.820 に答える
0

ここで loc は配列です:

var loc=[];

ここで loc は関数です:

function loc(x,y){loc.push({latitude:x,longitude:y});}

デバッガーはどの行でエラーを報告しますか?

于 2012-08-09T10:31:57.643 に答える