在antd pro內使用vue-amap,實現地圖和座標點。vue
1,安裝npm
npm install vue-amap --save
2,在main,js內引入antd
import VueAMap from 'vue-amap'; Vue.use(VueAMap); VueAMap.initAMapApiLoader({ key: 'YOUR_KEY', plugin: ['AMap.Autocomplete', 'AMap.PlaceSearch', 'AMap.Scale', 'AMap.OverView', 'AMap.ToolBar', 'AMap.MapType', 'AMap.PolyEditor', 'AMap.CircleEditor'], v: '1.4.4' });
3.在vue中使用,templateapp
<template> <div id="app"> <div class="amap-wrapper"> <el-amap ref="map" :vid="'amapDemo'" :center="center" :zoom="zoom" :plugin="plugin" :events="events" class="amap-demo" > <el-amap-marker v-for="u in markers" :position="u.position"></el-amap-marker> <el-amap-marker :position="[121.5273285, 31.21515044]" :icon="icon"></el-amap-marker> </el-amap> </div> </div> </template>
scriptthis
<script> export default { data() { return { center: [121.5273285, 31.21515044], zoom: 12, position: [121.5273285, 31.21515044], icon: '/huoche.png', events: { init(o){ console.log(o.getCenter()); }, zoomchange: (e) => { console.log(e); }, zoomend: (e) => {
//獲取當前縮放zoom值 console.log(this.$refs.map.$$getInstance().getZoom()); console.log(e); }, click: e => { alert('map clicked') } }, markers: [ { position: [121.5273285, 31.41515044] }, { position: [121.5273286, 31.31515045] } ],
//使用其餘組件 plugin: [ { pName: 'Scale', events: { init(instance) { console.log(instance) } } }, { pName: 'ToolBar', events: { init(instance) { console.log(instance) } } } ] } }, } </script>