美文网首页
vue 使用高德地图定位所在位置

vue 使用高德地图定位所在位置

作者: Gaochengxin | 来源:发表于2023-07-11 10:46 被阅读0次

1、获取key
我们需要到[高德]开放平台生成key

image.png

我这里选的是web端,提交后会生成一个key值

image.png image.png

2、安装vue-amap

       npm install vue-amap --save

3、在项目main.js引入vue-amap

import AMap from 'vue-amap';
Vue.use(AMap);

  // 初始化vue-amap
AMap.initAMapApiLoader({
  // 高德key
  key: '放入你的key',
  // 插件集合 (插件按需引入)
  plugin: ['AMap.Geolocation'] 
      });

3.使用

 <template>
 <div class="box">
    <div :style="{width:'100%',height:'300px'}">
      <el-amap vid="amap" :plugin="plugin" class="amap-demo" :center="center"></el-amap>
    </div>
</div>
</template>

<script>
export default {
data(){
  const self = this;
  return {
    center: [121.59996, 31.197646],
    lng: 0,
    lat: 0,
    loaded: false,
    plugin: [{
      enableHighAccuracy: true,//是否使用高精度定位,默认:true
      timeout: 100,          //超过10秒后停止定位,默认:无穷大
      maximumAge: 0,           //定位结果缓存0毫秒,默认:0
      convert: true,           //自动偏移坐标,偏移后的坐标为高德坐标,默认:true
      showButton: true,        //显示定位按钮,默认:true
      buttonPosition: 'RB',    //定位按钮停靠位置,默认:'LB',左下角
      showMarker: true,        //定位成功后在定位到的位置显示点标记,默认:true
      showCircle: true,        //定位成功后用圆圈表示定位精度范围,默认:true
      panToLocation: true,     //定位成功后将定位到的位置作为地图中心点,默认:true
      zoomToAccuracy:true,//定位成功后调整地图视野范围使定位位置及精度范围视野内可见,默认:f
      extensions:'all',
      pName: 'Geolocation',
      events: {
        init(o) {
          // o 是高德地图定位插件实例
          o.getCurrentPosition((status, result) => {
            console.log(result)
            if (result && result.position) {
              self.lng = result.position.lng;
              self.lat = result.position.lat;
              self.center = [self.lng, self.lat];
              self.loaded = true;
              self.$nextTick();
            }
          });
        }
      }
    }]
  }
}
}
</script>

相关文章

网友评论

      本文标题:vue 使用高德地图定位所在位置

      本文链接:https://www.haomeiwen.com/subject/aswyudtx.html