Маркер листовки по щелчку

#events #leaflet #click #marker

#Мероприятия #листовка #нажмите #маркер

Вопрос:

Возможно ли в leafletjs создать маркер, щелкнув по карте, я уже пробовал много разных вещей, но ничего не получалось. Я имею в виду, как создать событие щелчка, в котором создается маркер.

Это мой код, в этом примере я попытался создать функцию, которая создает маркер в определенной позиции, если щелкнуть в любом месте, но моя цель — создать маркер в том месте, где вы нажимаете. Я действительно новичок в этом языке и листовке, поэтому извините, если этот код глупый.

 <!DOCTYPE html>
<html>
    <head>
        <!--<meta charset="utf-8">
        <meta name="viewport" content="initial-scale=1, maximum-scale=1,
         user-scalable=no, width=device-width">
        <title>Blank App</title>-->
        <link rel="stylesheet" href="https://unpkg.com/leaflet@1.7.1/dist/leaflet.css">
        <script src="https://unpkg.com/leaflet@1.7.1/dist/leaflet.js"
           integrity="sha512-XQoYMqMTK8LvdxXYG3nZ448hOEQiglfqkJs1NOQV44cWnUrBc8PkAOcXy20w0
           vlaXaVUearIOBhiXZ5V3ynxwA=="
           crossorigin=""></script>
        <style>
            #mapid {position: absolute; top: 0; bottom: 0; left: 0; right: 0;}
        </style>
    </head>
    <body>
        <div id="mapid"></div>
        <script>
            var mymap = L.map('mapid').setView([0, 0], 1);
        
            L.tileLayer('https://api.maptiler.com/maps/streets/{z}/{x}/{y}.png?key=UVvjZnbqOD4DfEYUrXxm', {
                attribution:'<a href="https://www.maptiler.com/copyright/" target="_blank">amp;copy; MapTiler</a> <a href="https://www.openstreetmap.org/copyright" target="_blank">amp;copy; OpenStreetMap contributors</a>',
            }).addTo(mymap);


            function onMapClick(e) {
                var marker = L.marker([50.5, 30.5]).addTo(map);
            }
            mymap.on('click', onMapClick);

        </script>
    </body>
</html>
 

Комментарии:

1. Какой код вы пробовали? Пожалуйста, укажите это в вопросе

Ответ №1:

Используйте latlng из события также используйте mymap :

  function onMapClick(e) {
                var marker = L.marker(e.latlng).addTo(mymap);
            }
            mymap.on('click', onMapClick);