第一步: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>