vue-cli的項目中搭建vue-amap來使用高德地圖

第一步:vue

npm install vue-amap --savenpm

第二步: this

main.js中進行配置spa

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

  // 初始化vue-amap
AMap.initAMapApiLoader({
  // 高德key
  key: '4365df5e295713cc4d8dcbdcef934a0f',
  // 插件集合 (插件按需引入)
  // plugin: ['AMap.Geolocation']
  plugin: ['AMap.Geocoder','AMap.Geolocation','AMap.Autocomplete', 'AMap.PlaceSearch', 'AMap.Scale', 'AMap.OverView', 'AMap.ToolBar', 'AMap.MapType', 'AMap.PolyEditor', 'AMap.CircleEditor']
});

第三步:插件

在頁面中進行使用,如下提供的代碼的功能包括顯示點標記,提供搜索並更新點標記,地圖點擊後獲取地址經緯度與地址。code

<template>
    <div class="amap-page-container">
        <el-amap-search-box class="search-box" :search-option="searchOption" :on-search-result="onSearchResult"></el-amap-search-box>
        <el-amap
        vid="amapDemo"  
        :center="center"
        :zoom="zoom"  
        class="amap-demo"
        :events="events">
        <el-amap-marker :position="marker.position" :events="marker.events" :visible="marker.visible" :draggable="marker.draggable"></el-amap-marker>
        </el-amap>
        <div class="toolbar">position: [{{ lng }}, {{ lat }}] address: {{ address }}</div>
    </div>
</template>

<style>
.el-vue-amap-container.amap-demo{
    width: 800px;
    height: 500px;
}
.search-box {
  position: absolute;
  top: 25px;
  left: 20px;
}
.amap-page-container {
  position: relative;
}
</style>
<script>
    module.exports = {
      data: function() {
        let self = this;
        return {
          zoom: 20,
          center: [121.52014, 31.198862],
          searchOption: {
            city: '全國',
            citylimit: true
          },
          marker: {
            position: [121.52014, 31.198862]
          },
          address: '',
          events: {
            click(e) {
              let { lng, lat } = e.lnglat;
              self.lng = lng;
              self.lat = lat;
              self.marker.position = [lng, lat]
              // 這裏經過高德 SDK 完成。
              var geocoder = new AMap.Geocoder({
                radius: 1000,
                extensions: "all"
              });        
              geocoder.getAddress([lng ,lat], function(status, result) {
                if (status === 'complete' && result.info === 'OK') {
                  if (result && result.regeocode) {
                    self.address = result.regeocode.formattedAddress;
                    self.$nextTick();
                  }
                }
              });        
            }
          },
          lng: 0,
          lat: 0
        };
      },
      methods: {
        onSearchResult(pois) {
          console.log(pois,'pois')
          var lng = pois[0].lng
          var lat = pois[0].lat
          this.center = [lng, lat];
          this.marker.position = [lng, lat]
        }
      }
    };
</script>
相關文章
相關標籤/搜索