0

非常に簡単な質問があります、

私はグーグルに住所と以下を含むgsp変数の間の距離を計算させようとします

[53.57532, 10.01534]

変数を取得できませ${center}google.maps.LatLng-Object

ここに関数があります

jQuery(document).ready(function() {
var result = '${center}';
console.log(result);// [53.57532, 10.01534]
var origin = new google.maps.LatLng(55.930385, -3.118425);
var destination = new google.maps.LatLng(result);



var service = new google.maps.DistanceMatrixService();
service.getDistanceMatrix(
{
origins: [origin],
destinations: [destination],
travelMode: google.maps.TravelMode.DRIVING,
avoidHighways: false,
avoidTolls: false
}, callback);

function callback(response, status) {
if (status == google.maps.DistanceMatrixStatus.OK) {
console.log('status OK!');//status OK!
var origins = response.originAddresses;
var destinations = response.destinationAddresses;

for (var i = 0; i < origins.length; i++) {
  var results = response.rows[i].elements;
  for (var j = 0; j < results.length; j++) {
    var element = results[j];
    var distance = element.distance.text;
    var duration = element.duration.text;
    var from = origins[i];
    var to = destinations[j];
    console.log(distance);//Uncaught TypeError: Cannot read property 'text' of undefined 
  }
 }
}
}
});

上記の「ソースコード」でグーグルはエラーをスローします

 Uncaught TypeError: Cannot read property 'text' of undefined 

私は無意味なたわごとをたくさん試しましたが、私はそれを取得できません、

多分誰かが私が間違っていることのヒントを与えることができますか?前もって感謝します

コメントによると、ここにある私のgmap3も失敗しますが、これを機能させるにはかなり苦労しますが、ここでも同じ問題であり、緯度経度に変換しても機能しません。

  function getDistance(adress){
var to;
var result = '${center}';



 $("#getdistance").gmap3({
 getdistance:{
  options:{
  origins:adress,
  destinations:result ,
  travelMode: google.maps.TravelMode.DRIVING
},
 callback: function(results, status){
  var html = "";
  if (results){
    for (var i = 0; i < results.rows.length; i++){
      var elements = results.rows[i].elements;
      for(var j=0; j<elements.length; j++){
        switch(elements[j].status){
          case "OK":
            html += elements[j].distance.text + " (" + elements[j].duration.text + ")<br />";
            break;
          case "NOT_FOUND":
            html += "The origin and/or destination of this pairing could not be geocoded<br />";
            break;
          case "ZERO_RESULTS":
            html += "No route could be found between the origin and destination.<br />";
            break;
        }
      }
    }
  } else {
    html = "error";
  }
  console.log('start '+adress);
  console.log('start '+latte);
  console.log('start '+html);
}
}
});

}

ここでは、アドレスを関数の文字列として解析しています。adress

4

1 に答える 1

5

どうですか

var result = ${center};
var destination = new google.maps.LatLng(result[0], result[1]);

google.maps.LatLng配列を受け入れません。受け入れる引数は、number、number、boolです。

https://developers.google.com/maps/documentation/javascript/reference#LatLng

于 2013-03-09T20:51:27.270 に答える