百度地图API 循环添加信息窗口问题
百度地图API循环添加信息窗口,会出现所有消息只显示在第一个窗口的位置的问题.并且信息内容相同
解决方法1
转载自
https://blog.csdn.net/zz_mm/article/details/7600901
function initBaiDuMap(d) {
var markers = [];
for (var i = 0; i < d.length; ++i) {
if (null == d[i].LBSInfo || '' == d[i].LBSInfo)
continue;
(function (x) {
var lbsInfo = JSON.parse(d[x].LBSInfo);
var gcPoint = wgs84togcj02(parseFloat(lbsInfo.lon), parseFloat(lbsInfo.lat));
var bPoint = gcj02tobd09(gcPoint[0], gcPoint[1]);
var targetPoint = new BMapGL.Point(bPoint[0], bPoint[1]);
var markerTarget = new BMapGL.Marker(targetPoint);
map.addOverlay(markerTarget);
//基站返回的半径有误差,*2.5
var circle = new BMapGL.Circle(targetPoint, lbsInfo.radius * 2.5, {
strokeColor: 'blue',
strokeWeight: 1,
strokeOpacity: 0,
fillColor: 'blue',
fillOpacity: 0.1
});
map.addOverlay(circle);
markers.push(markerTarget);
var msg_info = "编号:" + d[x].MachineSN + '<br/>' + '名称:' + d[x].MachineName + '<br/>更新时间:' + d[x].LastConnectTime;
var opts = {
width: 240, // 信息窗口宽度
height: 100, // 信息窗口高度
title: 'LTE设备编号:' + d[x].DevLTE_SN, // 信息窗口标题
message: '设备信息'
};
var infoWindow = new BMapGL.InfoWindow(msg_info, opts); // 创建信息窗口对象
markerTarget.addEventListener("click", function () {
map.openInfoWindow(infoWindow, targetPoint); //开启信息窗口
});
})(i);
}
var centerPoint = new BMapGL.Point(121.46158672149517, 31.322417370168107);
map.centerAndZoom(centerPoint, 7); // 初始化地图,设置中心点坐标和地图级别
map.enableScrollWheelZoom(true); //开启鼠标滚轮缩放
//map.setHeading(60); //设置地图旋转角度
//map.setTilt(0); //设置地图的倾斜角度
}
同样是一个循环,但是在循环中使用了一个匿名函数,从而造成一个闭包将 i 的值锁定在里面,这样外部的值已经变化,
但是传到闭包里面的值已经被保留,也就可以顺利拿到应该取到的address[i]的内容了。
这样虽然解决了问题,但是每添加一个点都会创建一个匿名函数,内存泄漏可能会是潜在隐患。
接下去, 我们就可以自由的在地图上标注点并显示对应的信息了!
方法2 推荐
把var换成let
function initBaiDuMap(d) {
var markers = [];
for (var i = 0; i < d.length; ++i) {
if (null == d[i].LBSInfo || '' == d[i].LBSInfo)
continue;
if (null == d[i].LBSInfo || '' == d[i].LBSInfo)
continue;
var lbsInfo = JSON.parse(d[i].LBSInfo);
var gcPoint = wgs84togcj02(parseFloat(lbsInfo.lon), parseFloat(lbsInfo.lat));
var bPoint = gcj02tobd09(gcPoint[0], gcPoint[1]);
let targetPoint = new BMapGL.Point(bPoint[0], bPoint[1]);
let markerTarget = new BMapGL.Marker(targetPoint);
map.addOverlay(markerTarget);
//基站返回的半径有误差,*2.5
var circle = new BMapGL.Circle(targetPoint, lbsInfo.radius * 2.5, {
strokeColor: 'blue',
strokeWeight: 1,
strokeOpacity: 0,
fillColor: 'blue',
fillOpacity: 0.1
});
map.addOverlay(circle);
markers.push(markerTarget);
let msg_info = "编号:" + d[i].MachineSN + '<br/>' + '名称:' + d[i].MachineName + '<br/>更新时间:' + d[i].LastConnectTime;
let opts = {
width: 240, // 信息窗口宽度
height: 100, // 信息窗口高度
title: 'LTE设备编号:' + d[i].DevLTE_SN, // 信息窗口标题
message: '设备信息'
};
let infoWindow = new BMapGL.InfoWindow(msg_info, opts); // 创建信息窗口对象
markerTarget.addEventListener("click", function () {
map.openInfoWindow(infoWindow, targetPoint); //开启信息窗口
});
}
var centerPoint = new BMapGL.Point(121.4617, 32.32247);
map.centerAndZoom(centerPoint, 7); // 初始化地图,设置中心点坐标和地图级别
map.enableScrollWheelZoom(true); //开启鼠标滚轮缩放
//map.setHeading(60); //设置地图旋转角度
//map.setTilt(0); //设置地图的倾斜角度
}
var跟let区别
1 var是函数作用域,let是块作用域。
在函数中声明了var,整个函数内都是有效的,比如说在for循环内定义的一个var变量,实际上其在for循环以外也是可以访问的
而let由于是块作用域,所以如果在块作用域内定义的变量,比如说在for循环内,在其外面是不可被访问的,所以for循环推荐用let
2、let不能在定义之前访问该变量,但是var可以。
let必须先声明,在使用。而var先使用后声明也行,只不过直接使用但没有定义的时候,其值是undefined。var有一个变量提升的过程,当整个函数作用域被创建的时候,实际上var定义的变量都会被创建,并且如果此时没有初始化的话,则默认为初始化一个undefined
3、let不能被重新定义,但是var是可以的
百度地图API 循环添加信息窗口问题的更多相关文章
- 百度地图API 批量添加 带检索功能的信息窗口
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 百度地图API 循环向 marker 添加 click事件
使用百度地图API,循环向marker添加InfoWindow时,所有的marker点击弹出的inforwindow为最后一个添加的infowindow,百度后,使用js闭包解决此问题,直接贴代码: ...
- 谷歌地图 API 开发之信息窗口
信息窗口 简介 InfoWindow 在地图上方给定位置的弹出窗口中显示内容(通常为文本或图像).信息窗口具有一个内容区域和一个锥形柄.柄顶部与地图上的某指定位置相连. 通常,您会将信息窗口附加到标记 ...
- 调用百度地图api隐藏版权信息
调用百度地图API隐藏右下角版权信息 商用的话建议不要隐藏,避免侵权. 隐藏前: 隐藏后: .BMap_cpyCtrl { display: none; } .anchorBL { display: ...
- Python调用百度地图API实现批量经纬度转换为实际省市地点(api调用,json解析,excel读取与写入)
1.获取秘钥 调用百度地图API实现得申请百度账号或者登陆百度账号,然后申请自己的ak秘钥.链接如下:http://lbsyun.baidu.com/apiconsole/key?applicatio ...
- 百度地图API显示多个标注点并添加百度样式检索窗口
原作者博客地址:http://blog.csdn.net/a497785609/article/details/24009031 在此基础上进行了修改: 1.添加闭包,将i传入内部 2.添加地图和卫星 ...
- 百度地图api窗口信息自定义
百度地图加载完后,完全可以用dom方法操作,比较常用的就是点击mark的弹窗,利用jQuery可以很快的创建弹窗,需要注意的就是地图都是异步加载,所以绑定时间要用 jQuery 事件 - delega ...
- 【百度地图API】建立全国银行位置查询系统(五)——如何更改百度地图的信息窗口内容?
原文:[百度地图API]建立全国银行位置查询系统(五)--如何更改百度地图的信息窗口内容? 摘要: 酷讯.搜房.去哪儿网等大型房产.旅游酒店网站,用的是百度的数据库,却显示了自定义的信息窗口内容,这是 ...
- 百度地图API多个点聚合时,标注添加的标签label地图刷新就丢失的问题解决
当将自定义的Marker(含有Label)通过MarkerClusterer 管理的时候,当地图发生任何移动.缩放 的时候,Marker 的Label 就会自动消失. 这个问题主要是由于百度的点聚合A ...
- 百度地图API详解之事件机制,function“闭包”解决for循环和监听器冲突的问题:
原文:百度地图API详解之事件机制,function"闭包"解决for循环和监听器冲突的问题: 百度地图API详解之事件机制 2011年07月26日 星期二 下午 04:06 和D ...
随机推荐
- Linux内核社区迁移到github?
简介: github是目前最火的开源软件代码托管平台,那么Linux内核社区能否迁移到github上呢?Intel的Daniel Vetter写了一篇关于这个问题的博客,他给出的答案是NO.至于这个答 ...
- 技术干货|基于Apache Hudi 的CDC数据入湖「内附干货PPT下载渠道」
简介: 阿里云技术专家李少锋(风泽)在Apache Hudi 与 Apache Pulsar 联合 Meetup 杭州站上的演讲整理稿件,本议题将介绍典型 CDC 入湖场景,以及如何使用 Pulsa ...
- dotnet OpenXml SDK 形状填充渐变色的主题色
在 Office 文档的一些有趣的设计,颜色和画刷是可以继承的,这个继承包括了属性的继承.在形状填充里面使用的渐变色是可以一部分属性放在主题里面,主要找到主题里面的画刷,替换掉形状自己定义的内容,才是 ...
- linux 环境下idea 注册过期或激活异常解决
//@desn:linux 环境下idea 注册过期或激活异常解决 //@desn:码字不宜,转载请注明出处 //@author:张慧源 <turing_zhy@163.com> //@ ...
- Linux下ffmpeg库的编译链接
/usr/bin/ld: /usr/local/ffmpeg/lib/libavformat.a(aviobuf.o): in function `ff_crc04C11DB7_update':/ho ...
- 【python爬虫案例】爬取微博任意搜索关键词的结果,以“唐山打人”为例
目录 一.爬取目标 二.展示爬取结果 三.讲解代码 四.同步视频 4.1 演示视频 4.2 讲解视频 五.附:完整源码 一.爬取目标 大家好,我是马哥. 今天分享一期python爬虫案例,爬取目标是新 ...
- linux服务器配置查看
查看linux服务器配置 查硬盘信息 sblk 看sda sdb sdc之类的 以下可以看出是500G sda第一块,sdb是第二块 以下可以看出是 1T+100G 查内存 free -h 查cpu ...
- 03. go-zero简介及如何学go-zero
目录 一.go-zero简介及如何学go-zero 1.go-zero官方文档 2.go-zero微服务框架入门教程 3.go-zero最佳实践 4.学习资料 二.go-zero环境搭建 1.GO环境 ...
- Linux 开启防火墙端口策略
1. 安装防火墙 yum install firewalld systemd -y 2. 手动开放防火墙端口 查看防火墙全部设置 firewall-cmd --list-all 若防火墙服务未启动可执 ...
- 学习c# 7.0-7.3的ref、fixed特性并在Unity下测试
1.ref的一些运用 1.1 ref readonly 关于ref,一个主要应用是防止结构体拷贝,若返回的结构体不需要修改则用ref readonly,类似c++的const标记 : private ...