高德全局引入vuevue
1、安裝npm
一、npm install vue-amap --savewindows
二、在main.js中引入ide
import VueAMap from 'vue-amap'
Vue.use(VueAMap)
VueAMap.initAMapApiLoader({
key: '你的key',
plugin: ['AMap.Autocomplete', 'AMap.PlaceSearch', 'AMap.Scale', 'AMap.OverView', 'AMap.ToolBar', 'AMap.MapType', 'AMap.PolyEditor', 'AMap.CircleEditor'],
// 默認高德 sdk 版本爲 1.4.4
v: '1.4.4'
})
2、在組件中用測試
一、HTMLui
<el-amap
:plugin="plugin"
:center="center"
:zoom="zoom"
class="amap-demo">
<el-amap-marker v-for="marker in markers"
:position="marker.position"
:key="marker.id"
:events="marker.events"
:icon="'/static/police.png'">
</el-amap-marker>
<el-amap-info-window v-if="window"
:position="window.position"
:visible="window.visible"
:content="window.content"
:offset="window.offset">
</el-amap-info-window>
</el-amap>
二、scriptthis
data:code
zoom: 12,
center: [113.883107, 22.590993],
// 數據儲存
pointMarker:[],
markers: [],
windows: [],
window: '',
plugin: [{
pName: 'ToolBar',
events: {
init (instance) {
// console.log(instance)
}
}
}]
methods:
point () {
let markers = []
let windows = []
let that = this
this.pointMarker.forEach((item, index) => {
markers.push({
position: [item.lng, item.lat],
icon: item.icon,
events: {
click () {
that.windows.forEach(window => {
window.visible = false
})
that.window = that.windows[index]
that.$nextTick(() => {
that.window.visible = true
})
}
}
})
windows.push({
position: [item.lng, item.lat],
content: '<div class="windows-text">' + '<div class="text-map">' +
'<p>' + '煙感報警-方形測試' + '</p>' +
'報警狀態:' + item.status + '<br>' +
'報警時間:' + item.time + '<br>' +
'聯繫人:' + item.linkman + '<br>' +
'聯繫電話:' + item.phone + '<br>' +
'設備名稱:' + item.equipment + '<br>' +
'煙感環境溫度:' + item.temp + '<br>' +
'發現地址:' + item.site + '<br>' + '<div class="bottom">' +
'<button onclick="getVideo()">' + '查看視頻' + '</button>' + '</div>' + '</div>' + '</div>',
offset: [5, -15],
visible: false
})
})
// 加窗體
this.markers = markers
// 加彈窗
this.windows = windows
}
注意要給高度顯示地圖
.amap-demo{ width: 100%; height: 775px;}