vue-amap(vue 地图)

喜夏-厌秋 提交于 2019-12-01 20:10:39

昨天把vue的地图(高德)搞了下:

步骤:
1.去高德开发者平台申请key;
2.安装vue-amap;
3.使用组件调用地图

1.npm安装vue-amap
npm install vue-amap --save

2.在项目main.js引入vue-amap

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

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

3.重点来了

(1)在map.vue(我自己定义的 .vue) template 中加入

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


    <div class="toolbar">
        <span v-if="loaded">
          location: lng = {{ lng }} lat = {{ lat }}
        </span>
      <span v-else>正在定位</span>
    </div>
    <div
      v-on:click="req_post()"
    >
      查询周边
    </div>
  </div>
</template>
<style>
  .amap-demo {
    height: 300px;
  }
</style>

(2)在 script export default 中加入

      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();
                    }
                  });
                }
              }
            }]
          }
        }
   }

效果如下

DD19A1E3-C878-433E-B9EB-C47349447057.png


其中location: lng和 lat 为定位成功获取到的经纬度

 

但这只是定位,我们一般肯定是需要获取周围信息,并加以运用的,经过不屑努力找到了方法。

 req_post() {
            const that=this;
            const registerUrl="http://restapi.amap.com/v3/batch?key=您的高德key";
            const newUserInfo={
              "ops": [
                {
                  "url": "/v3/place/around?offset=10&page=1&key=您的高德key&location="+that.lng+","+that.lat+"&output=json&radius=100000&types=080000"
                }
              ]
            };
            that.axios.post(registerUrl, newUserInfo, {
              headers: {
                'Content-Type': 'application/x-www-form-urlencoded'
              }
            })
              .then(function (response) {
                console.log(response['data'][0]['body']['pois'])
              })
              .catch(function (error) {
                console.log(error);
              });

          }

获取的数据如下:

 

746924CC-0B01-49CD-8A58-DA438C1ABF9E.png


 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!