Vue结合高德地图实现HTML写自定义信息弹窗全过程
最近在写项目的时候有个需求就是根据点击地图上的点展示对应的信息,弹窗看着还挺花哨的。我在高德地图官网上还有各大平台找了如何自定义弹窗,可给出的大多数都是通过JS写HTML结构,我感觉这种不仅不好布局,而且可读性和维护性都不如直接写HTML好。于是我就在想,能不能在HTML里写这个弹窗呢?
答案是:能!
效果图如下:

先说下思路吧,通过看高德地图官方文档关于InfoWindow的介绍,可以看出信息弹窗的显示内容,可以是HTML要素字符串或者HTMLElement对象。于是我就想到了在Vue里不是可以通过this.$refs获取元素的DOM节点吗?然后我就开始了第一次尝试。

先看下后台返回的数据类型:
data: [
{
id: '1', //id
projectName: 'xxxx项目', //项目名称
address: '山东省济南市市中区xxxxxxxxxx', //项目地址
sketchMapUrl: '116.998232,36.651352', //项目坐标
startDate: '2022-06-18', //计划开始日期
completedDate: '2022-11-18', //计划结束日期
progress: '78', //施工进度
buildPeople: '32', //施工人员
alarmNum: '8' //告警信息数目
},{
id: '2', //id
projectName: 'xxxx项目', //项目名称
address: '山东省济南市市中区xxxxxxxxxx', //项目地址
sketchMapUrl: '116.998232,36.651352', //项目坐标
startDate: '2022-06-18', //计划开始日期
completedDate: '2022-11-18', //计划结束日期
progress: '78', //施工进度
buildPeople: '32', //施工人员
alarmNum: '8' //告警信息数目
}
],
我一看这种数据类型不就是用v-for吗?但是这个时候问题来了,不能直接循环后台返回的数据!
原因有二:
- 高德地图的AMap.InfoWindow的content属性不支持多个DOM根节点
- 不知道用户点击的哪一个点
必须经过筛选,判断用户点击的点.
this.data.map((item) => {
this.arr = item.sketchMapUrl.split(',')
//自定义点图标
this.marker = new AMap.Marker({
map: this.map,
icon: this.icon,
position: [this.arr[0], this.arr[1]],
offset: new AMap.Pixel(-13, -30),
//注意,我这里判断是给点加了个额外的参数,就是数据的id
extData: item.id
})
this.marker.on('click', (e) => {
this.singleData = []
//这里通过e.target._opts.extData和item.id进行比对,如果相同则把这项点的信息单独放一个数组里去遍历,就是html里的遍历数组
if (e.target._opts.extData === item.id) {
this.singleData.push(item)
}
this.infoWindow.open(this.map, e.target.getPosition())
})
})
这个时候可以判断点击的点了,下一步要做的就是实现自定义弹窗了。
代码如下:
<template>
<div class="web-box">
<!-- 地图 -->
<div id="map"></div>
<!-- 地图弹窗 -->
<div ref="infoWindow" class="infoWindow" >
<div class="container" v-for="(item,index) in singleData" :key="index">
<!-- 这里面写弹窗布局样式 -->
</div>
</div>
</template>
js代码:
//自定义信息窗体
this.infoWindow = new AMap.InfoWindow({
isCustom: true,
autoMove: true,
avoid: [20, 20, 20, 20],
content: this.$refs.infoWindow,
closeWhenClickMap: true,
offset: new AMap.Pixel(16, -30)
})
通过this.$refs.infoWindow拿到在HTML里写的弹窗节点,放在content内,这样我们就可以不用再写一些innerHTML和appendChild此类的代码了!
总结
到此这篇关于Vue结合高德地图实现HTML写自定义信息弹窗的文章就介绍到这了,更多相关Vue自定义信息弹窗内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue-Element-Admin集成自己的接口实现登录跳转
关于这个Vue-element-admin中的流程可能对于新的同学不是很友好,所以本文将结合实例代码,介绍Vue-Element-Admin集成自己的接口实现登录跳转,感兴趣的小伙伴们可以参考一下2021-06-06
Vue Element如何获取select选择框选择的value和label
文章介绍了两种使用Vue.js和ElementUI获取select选择框值的方法:一种是使用watch监听selectedValue的变化,另一种是使用@change事件,两种方法都能实现获取选择的value和label2025-01-01
vue页面设置滚动失败的完美解决方案(scrollTop一直为0)
这篇文章主要介绍了vue页面设置滚动失败的解决方案(scrollTop一直为0),本文通过场景分析实例代码相结合给大家介绍的非常详细,需要的朋友可以参考下2023-05-05
vue+el-element中根据文件名动态创建dialog的方法实践
本文主要介绍了vue+el-element中根据文件名动态创建dialog的方法实践,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2021-12-12


最新评论