How can I prevent a popup to show when clicking on a marker in Leaflet?(单击 Leaflet 中的标记时,如何防止显示弹出窗口?)
问题描述
我想要一个在我单击传单标记时不显示的弹出窗口.我不能使用 clickable : false
因为它会使标记充当底层地图的一部分".这对我来说是不可接受的.我尝试了以下代码:
I want a popup that doesn't show itself when I click on the Leaflet marker. I cannot use clickable : false
because it will make the markers "act as a part of the underlying map" and this is unacceptable for me. I tried the following code:
marker.on('click', function(event) {
event.originalEvent.preventDefault();
});
没有任何结果.在不使用标记对象的 clickable : false
属性的情况下,防止弹出窗口显示的正确方法是什么?
without any results. What is the right way to prevent a popup from showing without using the clickable : false
property of the marker object?
我只需要通过单击一个自定义按钮来打开地图上的所有弹出窗口,但我不希望在单击特定标记后弹出窗口显示自己.
All I need is to open all the popups on the map by clicking on one custom button, but I don't want the popups to show themselves after I click on a particular marker.
推荐答案
只是不要将弹出窗口绑定到标记.这是一个带有 2 个标记的 fiddle.一个有弹出窗口,另一个没有.
Just don't bind a popup to the marker. Here's a fiddle with 2 markers. One has a popup and the other does not.
L.marker([51, 0]).bindPopup("this is a popup").addTo(map);
L.marker([51, 1.5]).addTo(map);
我已经编辑了 fiddle 并认为这可能是您要问的.这是代码的重要部分:
I've edited the fiddle and think it might be what you are asking. Here's the important part of the code:
function onClick(event) {
event.target.closePopup();
}
这篇关于单击 Leaflet 中的标记时,如何防止显示弹出窗口?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:单击 Leaflet 中的标记时,如何防止显示弹出窗口?


- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- 400或500级别的HTTP响应 2022-01-01
- Fetch API 如何获取响应体? 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01
- 失败的 Canvas 360 jquery 插件 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- addEventListener 在 IE 11 中不起作用 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06