0

下面的当前代码甚至没有显示标记,但是当边界被移除时,标记开始出现。我不知道我哪里出错了。我要做的就是缩放地图以包含所有 3 个标记。目前它正在缩放到 0,0 。我确实提供了我的 api 密钥,所以这不是问题。

代码:

<html>
  <head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
      html { height: 100% }
      body { height: 100%; margin: 0; padding: 0 }
      #map_canvas { height: 100% }
    </style>
    <script type="text/javascript"
      src="https://maps.googleapis.com/maps/api/js?key=<key provided>&sensor=true">
    </script>

    <script type="text/javascript">
      function initialize() {
var markers = [
{ lat: 61.912113, lng: 61.912113 },{ lat: 62.912149, lng: 62.912144 },{ lat: 61.411123, lng: 61.411123 }];

        var mapOptions = {
center: new google.maps.LatLng(0,0),
          zoom: 8,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        var map = new google.maps.Map(document.getElementById("map_canvas"),
            mapOptions);

var bounds = new google.maps.LatLngBounds ();
var LatLngList = array (new google.maps.LatLng (markers[0].lat,markers[0].lng), new google.maps.LatLng (markers[1].lat,markers[1].lng), new google.maps.LatLng (markers[2].lat,markers[2].lng));
for (i = 0; i < markers.length; i++) {
var data = markers[i];

var myLatlng = new google.maps.LatLng(data.lat, data.lng);
var marker = new google.maps.Marker({
      position: myLatlng,
      map: map,
      title: "text"
  });
}
for (var i = 0; i < LatLngList.length; i++) {
  bounds.extend (LatLngList[i]);
}
map.fitBounds (bounds);
      }
    </script>
  </head>
  <body onload="initialize()">
    <div id="map_canvas" style="width:100%; height:100%"></div>
  </body>
</html>
4

1 回答 1

1

在此行上创建数组时出现错误(为了便于阅读,我截断了代码):

var LatLngList = array (new google.maps.LatLng (markers[0].lat,markers[0].lng) );

将其更改为:

var LatLngList = Array (new google.maps.LatLng (markers[0].lat,markers[0].lng) );

或者

var LatLngList = [ new google.maps.LatLng (markers[0].lat,markers[0].lng) ];
于 2013-02-07T05:47:24.307 回答