javascript - 唯一识别传单标记

标签 javascript php mysql json leaflet

我之前对这个主题做过一些研究,但我还没有找到我的特定问题的答案。我目前正在使用 Leaflet.js。每个标记都有从 MySQL 数据库中提取的弹出文本。但是,其中一些数据不会显示在弹出窗口中,仅与标记相关联。

我想做的是,每当单击特定标记时,与其关联的数据都会在弹出窗口以外的位置(即在 DIV 中)回显。

有没有一种方法可以唯一地标识标记,以便您可以提取与其关联的数据并在其他地方回显?

编辑: 这里有一些代码可以让事情更清楚一些:

这是我的一些 JS:

var json_data = <?php echo json_encode($data); ?>;

for (var i = 0; i < json_data.length; i++) {
    L.marker([json_data[i].latitude, json_data[i].longitude])
    .bindPopup(json_data[i].firstName + ' ' + json_data[i].lastName + '<br>' + '<strong>Date:</strong>' + ' ' + json_data[i].dateOccurred)
    .addTo(map);
  }

这是我的 PHP:

$query = "SELECT * FROM incident, victim WHERE incident.incidentID = victim.incidentID";
//converting the data from mySQL to PHP

$data = array(); //setting up an emtpy PHP array for the data to go into

if($result = mysqli_query($db,$query)) {
  while ($row = mysqli_fetch_assoc($result))
  {
    $data[] = $row;
  }
}
?>

基本上我通过 PHP 提取数据,然后将其编码为 JSON。

另外,谢谢你们的帮助,伙计们! :)

最佳答案

您可以尝试向标记添加自定义属性,然后在 onClick 事件中获取该属性:

//Handle marker click
var onMarkerClick = function(e){
    alert("You clicked on marker with customId: " +this.options.myCustomId);   
}
//Create marker with custom attribute
var marker = L.marker([36.83711,-2.464459], {myCustomId: "abc123"});
marker.on('click', onMarkerClick);

Example on JSFiddle

关于javascript - 唯一识别传单标记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31732215/

相关文章:

php - 根据商店分支选择表上的特定前缀

mysql - 在 mySQL 中连接 4 个表并包含 NULL 值

mysql - 创建一个包含需要与 3 个不同供应商匹配的邮政编码的关系数据库

mysql - 如何查询从上个月到12个月前的记录?

javascript - 为什么 event.target.value 在 JavaScript 中未定义?

javascript - 仅当在文本框中输入文本时才显示 X 按钮

javascript - 参数 jquery 和 HTML 5 canvas

php - jquery将变量添加到$.get url参数

php - 如何使用javascript将相同的变量从php发送到两个不同的php页面

php - 如何在PHP中合并docx文档?