如何使用" onclick"在Google地图上显示用户位置功能?

时间:2015-02-11 18:52:08

标签: javascript html google-maps onclick geolocation

我正在尝试建立一个显示地图的网站,我想在其上显示一个按钮,将您带到当前位置。 我正在使用谷歌地图服务来提取地图,我也设法自己获取用户位置所以所有的JavaScript似乎都工作正常,但是当将函数getlocation添加到代码并尝试从HTML调用它时不起作用。我相信这可能找不到功能,我无法弄清楚为什么? 我将保留以下代码:

<script>
 var map;

function initialize() {

var miami = new google.maps.LatLng(41.85, -87.65);

  var mapOptions = {
    zoom: 4,
    center: miami,
    disableDefaultUI: true,
  }
  map = new google.maps.Map(document.getElementById('mymap'),
                                mapOptions);

  var myloc = document.getElementById("try");

  function getlocation () {
    //code

    // Try HTML5 geolocation
  if(navigator.geolocation) {
    navigator.geolocation.getCurrentPosition(function(position) {
      var pos = new google.maps.LatLng(position.coords.latitude,
                                       position.coords.longitude);

      var infowindow = new google.maps.InfoWindow({
        map: map,
        position: pos,
        content: 'Location found using HTML5.'
      });

    }, function() {
      handleNoGeolocation(true);
    });
  } else {
    // Browser doesn't support Geolocation
    handleNoGeolocation(false);
  }
  }


function handleNoGeolocation(errorFlag) {
  if (errorFlag) {
    var content = 'Error: The Geolocation service failed.';
  } else {
    var content = 'Error: Your browser doesn\'t support geolocation.';
  }

  var options = {
    map: map,
    position: new google.maps.LatLng(60, 105),
    content: content
  };

  var infowindow = new google.maps.InfoWindow(options);


}
}


google.maps.event.addDomListener(window, 'load', initialize);

    </script>

我正在使用内联样式。我在某种程度上是JavaScript的新手,所以如果可以请告诉我我的错误在哪里或者我还需要从HTML调用一个函数来调用JavaScript上的函数。 另外这里是HTML按钮和地图div

    <style>
  html, body, #mymap{
    height: 100%;
    margin: 0px;
    padding: 0px
  }
</style>
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&signed_in=true"></script>
  <body>
    <div id="try"><button onclick="getlocation()">Click here</button></div>
    <div id="mymap"></div>
  </body>

如果你不明白我的问题是什么,请评论! 这是我的第一个问题!

1 个答案:

答案 0 :(得分:0)

google.maps.event.addListener(map, 'click', function(event) {

    marker = new google.maps.Marker({position: event.latLng, map: map});

});