高德地图获取当前定位信息

<!doctype html>
<html>
<head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no, width=device-width">
    <title>浏览器精确定位</title>
    <link rel="stylesheet" href="https://a.amap.com/jsapi_demos/static/demo-center/css/demo-center.css" />
    <style>
        html,body,#container{
            height:100%;
        }
        .info{
            width:26rem;
        }
    </style>
<body>
<div id='container'></div>
<div class="info">
    <h4 id='status'></h4><hr>
    <p id='result'></p><hr>
    <p id='address'></p><hr>
    <p >由于Chrome、IOS10等已不再支持非安全域的浏览器定位请求,为保证定位成功率和精度,请尽快升级您的站点到HTTPS。</p>
</div>
<script type="text/javascript" src="https://webapi.amap.com/maps?v=1.4.10&key=ad26780bfaabf0ca27ae6078e2e81682"></script>
<script type="text/javascript">
    var map,geolocation;
    
    map = new AMap.Map('container', {
        resizeEnable: true
    });
    map.plugin('AMap.Geolocation', function() {
        geolocation = new AMap.Geolocation({
	        enableHighAccuracy: true,//是否使用高精度定位,默认:true
	        timeout: 10000,          //超过10秒后停止定位,默认:无穷大
	        buttonPosition:'RB',    //定位按钮的停靠位置
	        buttonOffset: new AMap.Pixel(10, 20), //定位按钮与设置的停靠位置的偏移量,默认:Pixel(10, 20)
	        zoomToAccuracy: true,   //定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
        });
        
        map.addControl(geolocation);
        geolocation.getCurrentPosition();
      	AMap.event.addListener(geolocation, 'complete', onComplete); //返回定位信息
        AMap.event.addListener(geolocation, 'error', onError); //返回定位出错信息

    });
    //解析定位结果
    function onComplete(data) {
        document.getElementById('status').innerHTML='定位成功'
        var str = [];

        str.push('定位结果:' + data.position);
        str.push('定位类别:' + data.location_type);
        if(data.accuracy){
             str.push('精度:' + data.accuracy + ' 米');
        }//如为IP精确定位结果则没有精度信息
        str.push('是否经过偏移:' + (data.isConverted ? '是' : '否'));
        document.getElementById('result').innerHTML = str.join('<br>');
        
        var lnglatXY = [data.position.getLng(), data.position.getLat()];//地图上所标点的坐标
        AMap.service('AMap.Geocoder',function() {//回调函数
            geocoder = new AMap.Geocoder({
            });
            geocoder.getAddress(lnglatXY, function (status, result) {
                if (status === 'complete' && result.info === 'OK') {
                    //获得了有效的地址信息:
                    //即,result.regeocode.formattedAddress
                    console.log(result.regeocode.formattedAddress);
                    var address = result.regeocode.formattedAddress;
                    document.getElementById('address').innerHTML='详细地址:'+address;
                } else {
                    //获取地址失败
                }
            });
        })
       
    }
    //解析定位错误信息
    function onError(data) {
        document.getElementById('status').innerHTML='定位失败'
        document.getElementById('result').innerHTML = '失败原因排查信息:'+data.message;
    }
</script>
</body>
</html>

 

### Vue3 中集成高德地图 API 获取当前定位 在 Vue3 项目中集成高德地图获取用户的当前位置,可以通过以下方式实现。此过程涉及注册高德开发者账号、引入高德地图 JavaScript SDK 并使用 `AMap.Geolocation` 插件完成定位功能。 #### 1. 注册高德开发者账号并申请 Key 为了能够正常使用高德地图的服务,首先需要前往高德开放平台注册成为开发者,并创建应用以获得专属的 API 密钥[^1]。该密钥将在后续加载高德地图 JS 文件时被指定。 #### 2. 加载高德地图 JS 库 通过动态加载的方式,在 Vue 组件内部引入高德地图的 JavaScript SDK。以下是基于 Promise 的异步加载函数示例: ```javascript export default function MapLoader(key) { return new Promise((resolve, reject) => { if (window.AMap) { resolve(window.AMap); } else { const script = document.createElement('script'); script.type = 'text/javascript'; script.async = true; script.src = `https://webapi.amap.com/maps?v=1.4.15&key=${key}&callback=initAMap`; script.onerror = reject; document.head.appendChild(script); } window.initAMap = () => { resolve(window.AMap); }; }); } ``` 上述代码片段定义了一个名为 `MapLoader` 的工具函数用于按需加载高德地图库文件[^4]。 #### 3. 使用 AMap.Geolocation 进行定位 当成功初始化高德地图实例后,调用其内置插件 `AMap.Geolocation` 来请求设备的位置信息。下面是一个完整的 Vue3 组件案例演示如何操作这一流程: ```vue <template> <div id="mapContainer" style="width: 100%; height: 400px;"></div> </template> <script> import { onMounted } from "vue"; import MapLoader from "./utils/MapLoader"; export default { setup() { let mapInstance; async function initMapAndLocate() { try { // 替换为自己的高德地图 key const AMap = await MapLoader("your_amap_api_key_here"); mapInstance = new AMap.Map("mapContainer", { zoom: 12, }); const geolocationPlugin = new AMap.Geolocation({ enableHighAccuracy: true, // 是否启用高精度定位,默认:true timeout: 10000, // 超过10秒后停止定位,默认:无穷大 maximumAge: 0 // 定位结果缓存0毫秒,默认:0 }); mapInstance.addControl(geolocationPlugin); geolocationPlugin.getCurrentPosition(function(status, result){ if (status === 'complete') { console.log("用户位置:", result.position); // 输出纬经度对象 }else{ console.error("定位失败"); } }); } catch (error) { console.error(error.message || error); } } onMounted(() => { initMapAndLocate(); }); return {}; }, }; </script> ``` 以上代码展示了如何在一个简单的 Vue3 单文件组件里设置好地图容器并通过 `AMap.Geolocation` 执行精确定位[^3]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值