高德地址和百度地图获取当前定位(ip精准定位)

一、高德地图

1、创建一个高德应用key

安全密钥和key需要在高德开放平台创建一个应用,添加一个key,服务平台选择web端(JS API)
在这里插入图片描述
key创建好之后就可以获取到key和安全密钥
在这里插入图片描述

2、npm引入插件

// npm引入插件
npm i @amap/amap-jsapi-loader --save

3、使用geolocation.getCurrentPosition获取定位( ip精准定位失败率较高,失败后获取城市定位(普通ip定位)作为备用项)

// amp.js
import AMapLoader from "@amap/amap-jsapi-loader";
export function AMap() {
    window._AMapSecurityConfig = {
      securityJsCode: "", // 安全密钥
    };
    AMapLoader.load({
      key: "", // 申请好的Web端开发者Key,首次调用 load 时必填
      version: "2.0", // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15
      plugins: ["AMap.Scale"], //需要使用的的插件列表,如比例尺'AMap.Scale',支持添加多个如:['...','...']
    }).then((AMap) => {
      AMap.plugin("AMap.Geolocation", function () {
        const geolocation = new AMap.Geolocation({
          // 是否使用高精度定位,默认:true
          enableHighAccuracy: true,
          // 设置定位超时时间,默认:无穷大
          timeout: 10000,
          // 定位按钮的停靠位置的偏移量,默认:Pixel(10, 20)
          buttonOffset: new AMap.Pixel(10, 20),
          //  定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:false
          zoomToAccuracy: true,
          //  定位按钮的排放位置,  RB表示右下
          buttonPosition: "RB",
        });
        geolocation.getCurrentPosition(function (status, result) {
          if (status == "complete") {
            onComplete(result);
          }
          if (status == "error") {
            onError(result);
          }
        });
        function onComplete(data) {
          console.log(data);
          // data是具体的定位信息
        }
        function onError(data) {
          console.log(data);
          // data是具体的定位信息
          
          getCityInfo();// ip精准定位失败后获取城市定位(普通ip定位)
        }
		function getCityInfo() {
          // ip精准定位失败后获取城市定位(普通ip定位)
          geolocation.getCityInfo(function (status, result) {
            if (status == "complete") {
              onCityComplete(result);
              resolve();
            }
            if (status == "error") {
              onCityError(result);
              reject();
            }
          });
          function onCityComplete(data) {
            console.log("城市定位数据:", data);
            // data是具体的定位信息
          }
          function onCityError(data) {
            console.log("城市定位错误信息:", data);
            // data是具体的定位信息
            ElMessage.error(`获取定位失败,失败原因:${data.message}`);
          }
        }
      });
  });
}

在获取成功的方法中可把位置信息保存在localstorage中,需要使用的页面引入amp.js的AMap方法并使用即可

注意:网页访问地址是需要使用安全来源,比如:localhost或者https,使用http会报错。

二、百度地址获取定位

1、百度地图的key需要自己在百度地图开放平台创建的key,应用类型选:浏览器端

2、创建一个js文件:bmp.js,引入百度地图,内容如下:

// bmp.js
export function BMap() {
  return new Promise(function (resolve, reject) {
    window.init = function () {
      // eslint-disable-next-line
      resolve(BMapGL);
    };
    const script = document.createElement("script");
    script.type = "text/javascript";
    script.src = `https://api.map.baidu.com/api?v=1.0&type=webgl&ak=你的key&callback=init`;
    script.onerror = reject;
    document.head.appendChild(script);
  });
}

3、在需要获取定位的页面引入bmp.js,并使用

// 引入bmp.js
import { BMap } from "@/bmp.js";

// 获取定位方法
const get_loc = async () => { 
BMap()
    .then((BMapGL) => {
      var geolocation = new BMapGL.Geolocation();
      // 开启SDK辅助定位
      geolocation.enableSDKLocation();
      geolocation.getCurrentPosition(function (r: any) {
        console.log("位置信息:", r?.latitude, r?.longitude);
      });
    })
    .catch((err) => {
      console.log(err);
      ElMessage.error("访问地址经纬度接口失败,请重试");
    });
}
### 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]。 --- ###
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值