【问题标题】:Place marker on click google maps javascript api在点击谷歌地图javascript api上放置标记
【发布时间】:2023-03-30 00:30:02
【问题描述】:

我在 JS APIs 中编写了一个谷歌地图。

我想要实现的是,无论用户点击哪里,它都会将标记放在那里并输出其 Lat 和 Lng。

我所取得的成就是,无论我点击哪里,它都会输出 Lat 和 Lng,而无需将标记拖到那里。

这里是小提琴 - http://jsfiddle.net/sarthakbatra1991/87v0obb4/#&togetherjs=3aTj11AiwO

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


        document.getElementById("lat").value = event.latLng.lat();
        document.getElementById("long").value = event.latLng.lng();
        marker.setPosition(lat, lng);
        marker.setMap(map);

    });

请看一下并帮助我。

干杯!

【问题讨论】:

    标签: google-maps google-maps-api-3 google-maps-markers


    【解决方案1】:

    latlng 未在点击侦听器中定义。这应该有效:

    google.maps.event.addListener(map, 'click', function (event) {
      document.getElementById("lat").value = event.latLng.lat();
      document.getElementById("long").value = event.latLng.lng();
      marker.setPosition(event.latLng);
    });
    

    updated fiddle

    代码 sn-p:

    function initialize() {
      var myLatlng = new google.maps.LatLng(40.713956, -74.006653);
    
      var myOptions = {
        zoom: 8,
        center: myLatlng,
        mapTypeId: google.maps.MapTypeId.ROADMAP
      };
      var map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
    
      var marker = new google.maps.Marker({
        draggable: true,
        position: myLatlng,
        map: map,
        title: "Your location"
      });
    
      google.maps.event.addListener(marker, 'dragend', function(event) {
        document.getElementById("lat").value = event.latLng.lat();
        document.getElementById("long").value = event.latLng.lng();
      });
    
      google.maps.event.addListener(map, 'click', function(event) {
        document.getElementById("lat").value = event.latLng.lat();
        document.getElementById("long").value = event.latLng.lng();
        marker.setPosition(event.latLng);
      });
    }
    google.maps.event.addDomListener(window, "load", initialize());
    <style> html,
    body,
    #map_canvas {
      margin: 0;
      padding: 0;
      height: 100%
    }
    </style>
    <script src="https://maps.googleapis.com/maps/api/js"></script>
    Lat:
    <input id="lat" name="lat" val="40.713956" />Long:
    <input id="long" name="long" val="74.006653" />
    <br />
    <br />
    <div id="map_canvas" style="width: 500px; height: 250px;"></div>

    【讨论】:

    • 这非常有效。谢谢,@geocodezip。我会记住从下一次开始定义纬度和经度。 :D 干杯!
    猜你喜欢
    • 1970-01-01
    • 2016-04-08
    • 2012-09-27
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-08-15
    • 1970-01-01
    相关资源
    最近更新 更多