- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果这是新手问题,我很抱歉。我也在论坛内搜索,但没有找到类似我的问题。
我正在使用 leaflet(mapbox js),我有一个全局变量,它在一个名为 inicializarMapa()
的函数中使用。然后调用该函数,最后我使用 layerName.on('dbclick',function(){ Do something})
。但是控制台会触发一条消息,指出 “无法读取未定义的属性‘on’”
。
标记出现在我的 map 中。但我不知道为什么我不能做 dblclick 事件。
我希望你能帮我找出为什么变量会变成undefined
,非常感谢你抽出时间:)。
var myLayer;
function inicializarMapa(){
$.ajax({
url: 'consulta4.php',
data:{
},
method: 'POST',
dataType:'json',
success: function(data)
{
for(var i in data)
{
var geojson = [{
"type": "Feature",
"geometry": {
"type": "Point",
"coordinates": [data[i].longitude,data[i].latitude]
},
"properties": {
"title": "Emergencia: "+data[i].priority,
"id":data[i].id_emergency,
//"descripcion":"<button class='RE'>oisdjos</button>", Forma alternativa de añadir html
"icon": {
"iconUrl": data[i].imagen,
"iconSize": [50, 50], // size of the icon
"iconAnchor": [25, 50], // point of the icon which will correspond to marker's location
"popupAnchor": [0, -25], // point from which the popup should open relative to the iconAnchor
"className": "dot"
}
}
}]; //alert(data[i].longitude.valueOf());
myLayer = L.mapbox.featureLayer().setGeoJSON(geojson).addTo(map);
myLayer.on('click',function(e){
//console.log(e.layer.feature.properties.title);
map.panTo(e.layer.getLatLng());
});
myLayer.on('layeradd', function(e) {
marcadorEMG[i]= e.layer;
var feature = marcadorEMG[i].feature;
marcadorEMG[i].setIcon(L.icon(feature.properties.icon));
/*var popupContent = '<a target="_blank" class="popup" href="' + feature.properties.url + '">' +
'<img src="' + feature.properties.image + '" />' +
feature.properties.city +
'</a>'; */
var popupContent='<div class="contenedor-min-principal"><div class="contenedor-info"><b>'+feature.properties.title+'</b><p>Id emergencia:'+feature.properties.id+'</p></div><div class="contenedor-btn"><button class="emg" value="'+data[i].id_emergency+'">Modificar</button><button class="reporte" value="'+data[i].id_emergency+'">Reporte</button><button class="asistida" value="'+data[i].id_emergency+'">Finalizar</button></div><div class="contenedor-emg"><form class="formamin-emg">Dirección:<input type="text" id="direccion-emg-min" maxlength="50">Prioridad<select id="prioridad-emg-min"></select>Tipo punto interés<select id="tipo-pto-interes-emg-min"></select><div class="btn-final-aceptar"><input type="submit" value="Aceptar"></div></form></div></div>';//IMPORTANTISIMO
marcadorEMG[i].bindPopup(popupContent,{
closeButton: true,
minWidth: 300,
maxwidth:300
});
contadorEmergencias++;
});
myLayer.setGeoJSON(geojson);
contadorEMG=i;
}
}
});//Fin ajax emergencias
//////////////////////////////////////////////////////
}//fin inicializar mapa
inicializarMapa();
myLayer.on('dblclick',function(){alert("hi");});
最佳答案
发生这种情况是因为当您尝试将 dblclick
绑定(bind)到您的 myLayer
时,myLayer
还不包含 featureGroup 因为 inicializarMapa
仍在运行。您需要像处理 addlayer
和 click
事件一样绑定(bind)成功回调函数。
评论后编辑,这是你的成功方法,它在从 consulta4.php
加载完成后执行:
$.ajax({
url: 'consulta4.php',
data: {},
method: 'POST',
dataType:'json',
success: function (data) { // <- Start of your success method/function
} // <- end of your success method/function
});
你现在在做什么:
var myLayer;
$.ajax({
url: 'consulta4.php',
data: {},
method: 'POST',
dataType:'json',
success: function (data) { // <- Start of your success method/function
myLayer = L.mapbox.featureLayer();
} // <- end of your success method/function
});
// This is called before the success method has finished, so calling
// 'on' will fail because it's a method of featureLayer, and myLayer
// doesn't hold a featureLayer yet
myLayer.on('dblclick, function () {...});
因此,在变量 myLayer 上定义了 featureLayer 之后,您需要在 success
方法中绑定(bind)到 dblclick
事件:
var myLayer;
$.ajax({
url: 'consulta4.php',
data: {},
method: 'POST',
dataType:'json',
success: function (data) { // <- Start of your success method/function
myLayer = L.mapbox.featureLayer();
myLayer.on('dblclick, function () {...});
} // <- end of your success method/function
});
Edit²:您可以在 ajax 调用之前声明您的 featureLayer 并附加处理程序:
var featureLayer = L.mapbox.featureLayer().addTo(map);
featureLayer.on('dblclick', function () {});
$.ajax({
url: 'consulta4.php',
data: {},
method: 'POST',
dataType:'json',
success: function (data) {
featureLayer.setGeoJSON(data);
}
});
关于javascript - 在未定义的传单 js ("cannot read property ' 上创建的图层上使用 dblclick 事件时出现问题”),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34215309/
我有一个带有 LeafletJS 的项目。 例如,我在 map 中有 2 个点 (A, B)。我将其显示为 2 个标记 我必须画一条从 A 到 B 的折线。 我移动了标记 A,我想将标记 A 的折线的
是否可以向自定义图标标记添加文本?我想避免在图像编辑器中编辑图标只是为了添加文本。 我已经像这样创建了我的自定义图标标记: var airfieldIcon = L.icon({ ic
我想要一个 Leaflet 图层控件,选中/取消选中时必须显示/隐藏主图层内的所有子图层。我还想独立检查/取消选中子层。我浏览了 Leaflet 文档和论坛,但找不到任何引用资料。我应该为此编写一个自
如何处理 Leaflet map 库中的重叠线? 我从服务器 sid 下载 geoJSON 并将其绘制到 map 上。如果有两个相同的条目,Leaflet 会绘制它们两次。这可以通过在服务器端查找完全
我在项目中使用 leafletjs。在 map 上我有几个多边形和标记。当其中一个被点击时,所有这些都有一个点击事件来显示一些信息。如果用户单击 map 的“空白”部分(而不是任何多边形或标记),我想
我正在尝试对下一个边界的外观做出预测。这是一个plunkr: https://plnkr.co/edit/sk6NRh51WZA2vpWP 这就是我让它工作的方式,但它不是很有效: const ori
我是 Leaflet 的新手,目前我正在努力学习教程。到目前为止,我设法创建了一个交互式 clorophet map ,就像示例中的 http://leafletjs.com/examples/cho
我很难弄清楚为什么我无法在 map 上绘制正确的国家/地区。我已经完成了所有代码,但我仍然不明白为什么不能正常工作。 如果您看到任何问题,请告诉我。我很欣赏。 这是数据集 Country
是否可以在使用 Stamen Toner-lite tiles 的 Leaflet map 上设置中间(2.5、3.5、4.5 等)缩放级别? ?这是我到目前为止计算缩放级别的代码: leafletm
早上、下午或晚上。 我有以下位置数据(从'Count of sampling points within a grid cell'调整) # Demo data set.seed(123) # lat
大家好,我正在开发一个具有 map 功能的网站。我的目标是,如果您单击标记,则使其拖动。 这是我的代码 else if (select1.value === "Arson"){ var note =
我正在开发一个应用程序,用户可以在其中上传KML文件,并使用Leaflet,toGeoJSON和Angular-Leaflet-Directive在屏幕上呈现路径。 我使用toGeoJSON.kml(
我需要在多边形要素中实现多色填充。填充将根据要素属性进行有条件的格式化。 假设我需要一个具有 3 色图案的多边形,如下所示: let fillPalette = ['orange', 'green',
我从 javascript 开始,并试图解决这个问题。 我希望当用户单击 map 时出现一个表单。当他们填写表单时,我想在该位置创建一个标记,并将该标记的弹出内容设置为表单中的值。添加表单完成后,我还
我已经在地理服务器中发布了一个功能,我可以通过传单及其 basemap 成功访问该功能。现在我需要在弹出窗口中获取feature onclick的属性信息。 我按原样使用了示例( https://gi
我正在使用带有一些标记的传单 map 。我还有一个侧边栏,可以在其中看到标记的名称,如果单击标记的名称, map 将缩放到标记的 lnglat。它已经可以工作,但我的问题是,当我刷新页面并在侧边栏中选
我正在使用 Leaflet 和 Mapbox,我想设置 map 的 View : 所有标记均可见 中心设置为特定点 使用 setView 和 fitbounds 单独完成每个点很容易,但我不知道如何同
是否有所有潜在 map 源的列表?在示例页面上,可以浏览四种类型的 map 。外面还有什么? http://tombatossals.github.io/angular-leaflet-directi
我正在使用 Leaflet 制作交互式 map 。我在 map 上有标记(基于其经度和纬度坐标),并且我希望某些标记具有与其他标记不同的颜色。例如,某些坐标我给它的分数是“10”,我希望它是粉红色的,
我可能忽略了如何在 map 上更改 LeftletJS 的光标。 http://leafletjs.com/reference.htm 我尝试设置map_div.style.cursor = 'cro
我是一名优秀的程序员,十分优秀!