以下是我的工作示例http://members.upcpoczta.pl/w.racek/mapa.html
我想实现的是:
在鼠标悬停时保持高亮显示,就像现在一样,
当我点击突出显示的自行车路线时,我想保持缩放到功能,但当它放大到路线时,我想继续突出显示,直到我点击所选路线外面或移动地图。
现在它可以很好地放大,但是当你移动时,鼠标突出显示消失,而你却不知道你点击了哪条路线。
答案 0 :(得分:2)
好吧,有点hacky但是把它视为如何完成这样的事情的演示。创建变量selected
,并在click
处理程序被触发时将突出显示的功能存储在那里。现在,在mouseout
处理程序中,您需要检查是否进行了选择,看看它是否与触发mouseout
的图层相对应,如果是,则不要删除突出显示的样式。此外,您需要在click
处理程序中编写一些逻辑,如果已经进行了选择,则会从中删除突出显示。
代码示例:
function highlight (layer) {
layer.setStyle({
weight: 5,
dashArray: ''
});
if (!L.Browser.ie && !L.Browser.opera) {
layer.bringToFront();
}
}
function dehighlight (layer) {
if (selected === null || selected._leaflet_id !== layer._leaflet_id) {
geojson.resetStyle(layer);
}
}
// Variable to store selection
var selected = null;
function select (layer) {
// See if there is already a selection
if (selected !== null) {
// Store for now
var previous = selected;
}
map.fitBounds(layer.getBounds());
// Set new selection
selected = layer;
// If there was a previous selection
if (previous) {
// Dehighlight previous
dehighlight(previous);
}
}
var geojson = L.geoJson(rower, {
style: function (feature) {
return {
weight: 2,
opacity: 1,
color: feature.properties.colour,
dashArray: 3,
};
},
onEachFeature: function (feature, layer) {
layer.on({
'mouseover': function (e) {
highlight(e.target);
},
'mouseout': function (e) {
dehighlight(e.target);
},
'click': function (e) {
select(e.target);
}
});
}
}).addTo(map);
以下是关于Plunker的工作示例:http://plnkr.co/edit/fdTnA9CyJdJejiPq2q8M?p=preview
您还需要为地图click
或moveend
或您尝试完成的任何内容编写处理程序,并在那里检查是否有选择,然后删除突出显示它,但是一旦你掌握了这个概念,那就相当简单了。