I am trying to build a map application using leaflet.js and I can not figure out how to use the .off method. The documentation doesn't have any examples and I can't seem to find anything anywhere else online. I have distilled the problem into a more simple chunk of code so my question could be more clear.
我正在尝试使用传单构建一个地图应用程序。js和我不知道怎么用。off方法。文档中没有任何示例,我似乎也无法在网上找到其他任何地方。我已经将问题简化为更简单的代码块,这样我的问题就可以更清楚了。
Basically I have it set up so that when you click the 'enable click' link it will add an event listener that adds a marker to the map every time you click it. I want to remove that event listener when you click 'disable click'.
基本上我已经设置好了,所以当你点击“启用点击”链接时,它会添加一个事件监听器,每次你点击它时,它都会在地图上添加一个标记。当您单击“禁用单击”时,我想删除该事件监听器。
这是演示的链接
Here is the code I have now.
这是我现在的代码。
$(document).ready(function(){
var map, cloudmade, sanAntonio, polygonPoints
map = new L.Map('map');
cloudmade = new L.TileLayer('http://{s}.tile.cloudmade.com/d4334cd6077140e3b92ccfae2b363070/997/256/{z}/{x}/{y}.png', {
attribution: 'Map data © <a href="http://openstreetmap.org">OpenStreetMap</a> contributors, <a href="http://creativecommons.org/licenses/by-sa/2.0/">CC-BY-SA</a>, Imagery © <a href="http://cloudmade.com">CloudMade</a>',
maxZoom: 18
});
sanAntonio = new L.LatLng(29.4238889, -98.4933333); // geographical point (longitude and latitude)
map.setView(sanAntonio, 13).addLayer(cloudmade);
//everything above sets up the map
function enableClick(){
map.on('click', function(e) {
var marker = new L.Marker(e.latlng, {draggable:true});
map.addLayer(marker);
});//closes the click function
this.disableClick = function(){
map.off('click');
}
}
//when
$('#enable_click').click(function(){
var enable_click = new enableClick()
$('#disable_click').click(function(){
enable_click.disableClick;
});
});
});//closes the document ready function
I have already tried a bunch of different things so the whole 'this.disableClick' thing is just the latest strange thing I have tried. Anyone have a clue?
我已经试过一堆不同的东西了。去功能化只是我最近尝试的一件奇怪的事。有人知道吗?
1 个解决方案
#1
18
You need to pass the function to on
and off
by reference:
您需要通过引用将函数传递给on和off:
function doStuff() { ... }
map.on('click', doStuff);
...
map.off('click', doStuff);
#1
18
You need to pass the function to on
and off
by reference:
您需要通过引用将函数传递给on和off:
function doStuff() { ... }
map.on('click', doStuff);
...
map.off('click', doStuff);