谷歌地图标记移动时更新mysql数据库

时间:2013-10-29 08:38:01

标签: javascript php mysql ajax

嗯,我有一张谷歌地图,所有纬度和经度来自数据库,它用Marker显示每个位置。标记可移动。

现在我想在移动每个标记时更新数据库的纬度和经度。有可能使用php或javascript或Ajax。你能给我一个解决方案或建议吗?谢谢。

Javascript代码:

<script type="text/javascript" src="jquery-1.4.4.min.js"></script>        
<script src="http://maps.googleapis.com/maps/api/js?sensor=false" 
type="text/javascript"></script>
<script type="text/javascript" src="gmap3.js"></script>    

<script type="text/javascript">
  $(function(){
    $('#map').gmap3({
      map:{
        options:{
          center:[23.709920999999998,90.40714299999999],
          zoom: 15
        }
      },
      marker:{
        values:[            
        <?php
        $sql = mysql_query("select * from parkings where userid != '0'");
        while($res = mysql_fetch_array($sql)){
                            $id = $res['locId'];
            $lat = $res['latitude'];
            $long = $res['longitude'];              
            ?>
            {address:"<?php echo $lat;?>,<?php echo $long;?>"},
            <?php
            }
        ?>                               
        ],
        options:{
          draggable: true
        },
        events: {
          click: function(marker, event, context){
            markerSelected(context.id);
          }
        }
      }
    });

    $("#bcolor").click(function(){
      var marker = $('#map').gmap3({get: $("#markerId .value").text() });
      marker.setIcon(marker.getIcon() ? "" : "http://maps.google.com/mapfiles
/marker_green.png");
    });

    $("#bremove").click(function(){
      $('#map').gmap3({clear: $("#markerId .value").text() });
      $("#data").hide();
      $("#title").show();
    });

  });

  function markerSelected(id){
    var marker = $('#map').gmap3({get:id});

    $("#markerId .value").text(id);
    $("#latitude .value").text(marker.getPosition().lat());
    $("#longitude .value").text(marker.getPosition().lng());

    $("#data").show();
    $("#title").hide();
  }

</script>

Html正文部分代码

<div id="map" class="gmap3"></div>

当我点击每个标记时,它会显示以下部分的纬度和经度:

<div id="latitude">
        <span class="label">Latitude : </span>
        <span class="value"></span>
      </div>
      <div id="longitude">
        <span class="label">Longitude : </span>
        <span class="value"></span>
      </div>

1 个答案:

答案 0 :(得分:0)

移动标记时,可以使用jQuery获取新的纬度和经度值。

只需为包含值的标记添加ID:

<div id="latitude">
    <span class="label" id="gmap_latitude">Latitude : </span>
    <span class="value"></span>
</div>
<div id="longitude">
    <span class="label" id="gmap_longitude">Longitude : </span>
    <span class="value"></span>
</div>

因此,您可以使用jQuery轻松选择它们并获取它们的值。

现在,为了更新数据库,我建议创建一个更新数据库的PHP脚本,并在每次更新标记时使用带有jQuery加载函数(http://api.jquery.com/jQuery.post/)的AJAX调用。您可以使用jQuery事件处理程序跟踪它。