Vue结合高德地图怎么实现HTML写自定义信息弹窗 |
您所在的位置:网站首页 › js实现弹窗 › Vue结合高德地图怎么实现HTML写自定义信息弹窗 |
Vue结合高德地图怎么实现HTML写自定义信息弹窗
发布时间:2023-04-27 11:12:23
来源:亿速云
阅读:73
作者:iii
栏目:开发技术
这篇文章主要介绍“Vue结合高德地图怎么实现HTML写自定义信息弹窗”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue结合高德地图怎么实现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()) }) })这个时候可以判断点击的点了,下一步要做的就是实现自定义弹窗了。 代码如下: 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 |