下面是一些vue-amap的简单例子,下载和引入这里就不多说了。
直接上代码,把以下代码复制进去即可查看效果,亲测有效。
<template>
<div id="app">
<div class="amap-page-container">
<div class="toolbar">当前坐标: {{ lng }}, {{ lat }}</div>
<el-amap
vid="amapDemo"
:center="center"
:zoom="zoom"
:plugin="plugin"
class="amap-demo"
:events="events"
pitch-enable="false"
>
<el-amap-marker
v-for="(marker,index) in markers"
:key="index"
:events="marker.events"
:position="marker.position"
/>
<el-amap-info-window
v-if="window"
:position="window.position"
:visible="window.visible"
:content="window.content"
:offset="window.offset"
:close-when-click-map="true"
:is-custom="true"
>
<div id="info-window">
<p>{{ window.address }}</p>
<div class="detail" @click="checkDetail">查看详情</div>
</div>
</el-amap-info-window>
</el-amap>
</div>
</div>
</template>
<script>
export default {
name: "AmapPage",
data: function () {
const self = this;
return {
data: [
{
position: "113.645422, 34.730936",
address: "另一个地址",
},
{
position: "113.685313,34.746453",
address: "一个地址",
},
],
zoom: 10,
center: [113.645422, 34.730936],
markers: [],
windows: [],
window: "",
events: {
click(e) {
const { lng, lat } = e.lnglat;
self.lng = lng;
self.lat = lat;
},
},
lng: 0,
lat: 0,
/*一些工具插件*/
plugin: [
{
pName: "DistrictSearch",
events: {
init(o) {
console.log(o);
},
},
},
{
// 定位
pName: "Geolocation",
events: {
init(o) {
// o是高德地图定位插件实例
o.getCurrentPosition((status, result) => {
if (result && result.position) {
// 设置经度
self.lng = result.position.lng;
// 设置维度
self.lat = result.position.lat;
// 设置坐标
self.center = [self.lng, self.lat];
self.markers.push([self.lng, self.lat]);
// load
self.loaded = true;
// 页面渲染好后
self.$nextTick();
}
});
},
},
},
{
// 工具栏
pName: "ToolBar",
events: {
init(instance) {
// console.log(instance);
},
},
},
{
// 鹰眼(暂且没用到)
pName: "OverView",
events: {
init(instance) {
// console.log(instance);
},
},
},
{
// 地图类型
pName: "MapType",
defaultType: 0,
events: {
init(instance) {
// console.log(instance);
},
},
},
{
// 搜索(暂且没用到)
pName: "PlaceSearch",
events: {
init(instance) {
// console.log(instance)
},
},
},
],
};
},
mounted() {
this.point();
},
methods: {
point() {
const markers = [];
const windows = [];
const that = this;
this.data.forEach((item, index) => {
markers.push({
position: item.position.split(","),
// icon:item.url, //不设置默认蓝色水滴
events: {
click() {
// 方法:鼠标移动到点标记上,显示相应窗体
that.windows.forEach((window) => {
window.visible = false; // 关闭窗体
});
that.window = that.windows[index];
that.$nextTick(() => {
that.window.visible = true;
});
},
},
});
windows.push({
position: item.position.split(","),
isCustom: true,
offset: [115, 55], // 窗体偏移
showShadow: false,
visible: false, // 初始是否显示
address: item.address,
});
});
// 加点
this.markers = markers;
// 加弹窗
this.windows = windows;
},
checkDetail() {
alert("点击了查看详情");
},
},
};
</script>
<style scoped>
.amap-demo {
height: 120vh;
}
.amap-page-container {
position: relative;
}
#info-window {
width: 211px;
height: 146px;
margin-left: 30px;
background: rgba(255, 255, 255, 0.9);
border-radius: 4px;
position: relative;
overflow: hidden;
}
.detail {
width: 100%;
height: 24px;
color: #fff;
background-color: #1a73e8;
position: absolute;
bottom: 0;
font-size: 12px;
line-height: 24px;
text-align: center;
cursor: pointer;
}
</style>