百度地图JS-API:点击获取经纬度以及地址以及小红点显示定点坐标

本文介绍如何使用百度地图JS-API实现点击地图获取经纬度及详细地址,并展示定点坐标的小红点。通过实例代码,读者可以学习如何利用Geocoder获取详细地址信息,以及如何在地图上标记指定位置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

百度地图JS-API:点击获取经纬度以及地址以及小红点显示定点坐标

1.引入JS:ak后面是你的秘钥

在这里插入图片描述
2.使用div元素包裹地图:
在这里插入图片描述

3.具体实现

 var point = new BMap.Point(当前坐标);//当前坐标经纬可改
 map.centerAndZoom(point,17);//显示级数越大越细
 map.addOverlay(new BMap.Marker(point));//定点坐标红点覆盖

在这里插入图片描述

<script type="text/javascript">
    // 百度地图API功能
    var map = new BMap.Map("allmap");
    var point = new BMap.Point();//当前坐标经纬可改
    map.centerAndZoom(point,17);//显示级数越大越细
    map.addOverlay(new BMap.Marker(point));//定点坐标红点覆盖
    map.enableScrollWheelZoom(true);
    var geoc = new BMap.Geocoder();    

    map.addEventListener("click", function(e){   
        //通过点击百度地图,可以获取到对应的point, 由point的lng、lat属性就可以获取对应的经度纬度     
        var pt = e.point;
        geoc.getLocation(pt, function(rs){
            //addressComponents对象可以获取到详细的地址信息
            var addComp = rs.addressComponents;
            var site = addComp.province + ", " + addComp.city + ", " + addComp.district + ", " + addComp.street + ", " + addComp.streetNumber;
            //将对应的HTML元素设置值
            $("#site").val(site);
            $("#longitude").val(pt.lng);
            $("#latitude").val(pt.lat);
        });        
    });
</script>
在高德地图 JavaScript API 中,可以通过添加 click 事件监听器来实现获取点击标记的经纬度。具体实现步骤如下: 1. 在地图上搜索地址并添加标记: ``` // 使用地址解析功能,将地址解析为经纬度 var geocoder = new AMap.Geocoder({ city: '全国' // 城市,默认值:全国 }); geocoder.getLocation('北京市朝阳区望京SOHO', function(status, result) { if (status === 'complete' && result.info === 'OK') { // 解析成功时,获取经纬度信息 var location = result.geocodes[0].location; var latitude = location.lat; var longitude = location.lng; // 创建 Marker 对象 var marker = new AMap.Marker({ position: location, // 设置Marker坐标 title: 'Marker', // 设置Marker标题 visible: true // 设置Marker可见性 }); // 添加Marker到地图上 marker.setMap(map); } }); ``` 2. 在标记上添加 click 事件监听器: ``` // 创建 Marker 对象 var marker = new AMap.Marker({ position: [116.397428, 39.90923], // 设置Marker坐标 title: 'Marker', // 设置Marker标题 visible: true // 设置Marker可见性 }); // 添加Marker到地图上 marker.setMap(map); // 设置Marker点击事件监听器 AMap.event.addListener(marker, 'click', function() { // 获取Marker的经纬度信息 var position = marker.getPosition(); var latitude = position.getLat(); var longitude = position.getLng(); // 执行其他操作 }); ``` 以上代码示例中,获取到的经纬度信息分别保存在 latitude 和 longitude 变量中。您可以根据实际需求进行处理。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值