leaflet 鼠标移动到图层时变_leaflet中的事件穿透

本文介绍了在使用Leaflet时遇到的一个问题:当鼠标在地图上移动到重叠的Polygon图层时,总是触发下方图层的popup。经过分析,发现这是由于事件穿透导致的。Leaflet的popup特性使得地图上只能显示一个popup,因此当点击重叠区域时,上方图层触发事件后,下方图层的事件也会被触发,但popup显示的是下方图层的内容。为了解决这个问题,作者提供了一段代码示例,通过设置标志变量来控制popup的显示。
摘要由CSDN通过智能技术生成

在总结方法之前,先总结一下问题。

用过leaflet的人都知道,leaflet中有这样一个方法:

L.geoJSON(data, {

style:function(feature) {return{color: feature.properties.color};

}

}).bindPopup(function(layer) {returnlayer.feature.properties.description;

}).addTo(map);

这个方法可以将封装好的GeoJson直接转化为FeatureGroup,非常方便。

GeoJson 的 featureType 有多种,这里拿 Point 和 Polygon 两类来举例说明,它们在 leaflet 中是两个代表。Point 类型的 geojson 数据在转化为地图图层的渲染方式是 marker,本质上是 div,也就是说,如果你的 geojson 里有 1 万条数据,那它就会在地图上创建 1 万个 div,很恐怖有木有,事实上也是不可取,因为一口气创建一万个 div 还是带来了很大的工作量,一般配置的电脑上运行这样的页面会卡出翔;再说 Polygon 多边形类型,Polygon  类型的 geojson 数据在转化为地图图层的渲染方式是 Canvas,这与 marker 有本质上的区别,即使你的 geojson 里有 1 万条数据,它也只会在其所在的 Pane 上创建 1 个 Canvas标签,页面地图流畅程度丝毫不受影响。

说到这里,其实离本文的问题已经跑远了,但说这些也是为了更好的理解这个问题或者说现象。div 是有层级关系(zIndex)的,而

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值