Gaode map: generate a marker at the clicked position on the map

map.on('click',function(e){
    
    
   let lng = e.lnglat.getLng(), lat = e.lnglat.getLat();
   if(lng && lat){
    
    
     var mymessage = confirm("是否以当前位置作为设备经纬度地址?");
     if(mymessage == true){
    
    
       let dom = document.getElementById('lnglat')
       dom.value = `${
      
      lng},${
      
      lat}`;
       //显示marker点
       markerOpen(lng,lat)
       /*
         el --- input 元素
         dispatchEvent() --- 给节点分派一个合成事件;
           该方法将分派一个合成事件,它由 Document.createEvent() 创建,
           由 Event 接口或它的某个子接口定义的初始化方法初始化。
           调用该方法的节点将成为事件的目标节点,该事件在捕捉阶段中第一次沿着文档树向下传播。
           如果该事件的 bubbles 属性为 true,那么在事件的目标节点自身处理事件后,它将沿着文档树向上起泡
         new Event('input') --- 给元素分配 input 事件
       */
       // dom.dispatchEvent(new Event('input'));
     }
   }
 })

function markerOpen(lng,lat){
    
    
   map.remove(markers)
   markers = [];
   let imgsrc1 = require('@/assets/gif/g1.gif');
   if(!lng || !lat){
    
    return};
   markers.push(new AMap.Marker({
    
    
     map:map,
     position:[lng,lat],
     icon:new AMap.Icon({
    
    image:imgsrc1,imageSize:new AMap.Size(10,10)}),
     offset: new AMap.Pixel(-5, -5)
   }))
 }

Guess you like

Origin blog.csdn.net/qq_41752378/article/details/129436446