Vue结合高德地图怎么实现HTML写自定义信息弹窗

您所在的位置:网站首页 js实现弹窗 Vue结合高德地图怎么实现HTML写自定义信息弹窗

Vue结合高德地图怎么实现HTML写自定义信息弹窗

2023-05-05 17:20| 来源: 网络整理| 查看: 265

Vue结合高德地图怎么实现HTML写自定义信息弹窗 发布时间:2023-04-27 11:12:23 来源:亿速云 阅读:73 作者:iii 栏目:开发技术

这篇文章主要介绍“Vue结合高德地图怎么实现HTML写自定义信息弹窗”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue结合高德地图怎么实现HTML写自定义信息弹窗”文章能帮助大家解决问题。

效果图如下:

Vue结合高德地图怎么实现HTML写自定义信息弹窗

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

Vue结合高德地图怎么实现HTML写自定义信息弹窗

先看下后台返回的数据类型:

      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())     }) })

这个时候可以判断点击的点了,下一步要做的就是实现自定义弹窗了。

代码如下:

                                            

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自定义组件如何实现v-model双向绑定数据 如何解决SpringBoot与Vue交互跨域问题

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:[email protected]进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue html 上一篇新闻:Vue不同项目之间传递、接收参数问题怎么解决 下一篇新闻:react组件封装input框的防抖怎么处理 猜你喜欢 java中各种对象的比较方法是什么 Vue2怎么用echarts绘制折线图,饼图和大图 Spring JPA之find拓展方法有哪些 怎么通过Java实现SSL交互功能 怎么使用MAT进行JVM内存分析 C++日期类计算器怎么实现 Ribbon的饥饿加载模式怎么解决 C语言跳转浏览器打开指定URL的代码怎么写 Spring JPA find分页方法怎么使用 PHP中trait的使用和同时引入多个trait时同名方法冲突怎么处理


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3