使用MySQL、JSON和jQuery插件Gmap3填充Google地图标记

使用MySQL、JSON和jQuery插件Gmap3填充Google地图标记,jquery,mysql,json,google-maps,jquery-gmap3,Jquery,Mysql,Json,Google Maps,Jquery Gmap3,我无法显示从MySQL数据库中提取的数据。JSON格式不正确,尽管JSON是有效的。我想至少有两种方法可以解决我的问题,1。更改MySQL查询或2。在使用Gmap3构建Google地图之前,使用jQuery操作JSON输出。我和他们中的任何一个都在斗争 my-JSON.php中的MySQL查询和JSON编码: try { $db = new mysqli(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME); $tatorte = $db->query("

我无法显示从MySQL数据库中提取的数据。JSON格式不正确,尽管JSON是有效的。我想至少有两种方法可以解决我的问题,1。更改MySQL查询或2。在使用Gmap3构建Google地图之前,使用jQuery操作JSON输出。我和他们中的任何一个都在斗争

my-JSON.php中的MySQL查询和JSON编码:

try {

$db = new mysqli(DB_HOST, DB_USER, DB_PASSWORD, DB_NAME);

$tatorte = $db->query("
    SELECT p.post_title as title,
        max(case when pm.meta_key = '_cmb_tatort_map_latitude' then pm.meta_value end) as lat,
        max(case when pm.meta_key = '_cmb_tatort_map_longitude' then pm.meta_value end) as lng,
        max(case when pm.meta_key = '_cmb_subline' then pm.meta_value end) as subline,
        max(case when pm.meta_key = '_cmb_teaser_text' then pm.meta_value end) as teaser
    FROM mob_posts p join
        mob_postmeta pm
        on pm.post_id = p.ID
    WHERE pm.meta_key in ('_cmb_tatort_map_latitude', '_cmb_tatort_map_longitude', '_cmb_subline', '_cmb_teaser_text') and
        p.post_type = 'tatort'
        group by p.id
    ORDER BY p.id DESC
    LIMIT 100;
");

$rows = array();

while ($locations = $tatorte->fetch_assoc()) {
    $rows[] = array('values' => $locations);
}

$json = array(
    "center" => array(51.95026490,11.69227350), // center map at a given location
    "tatorte" => $rows
);

header('Content-Type: application/json; charset=UTF-8;');
echo json_encode( $json );

} catch (Exception $e) {
    echo $e->getMessage();
}
这似乎很好,我得到了一个有效的JSON,如下所示:

{
    "center":[
        51.9502649,
        11.6922735
    ],
    "tatorte":[
        {
            "values":{
                "title":"my title",
                "lat":"51.7920562",
                "lng":"11.141447999999968",
                "subline":"my sublime",
                "teaser":"my teaser text"
            }
        }
   ]
}
显然,格式应该是这样的:

{
    "center": [
        46.578498,
        2.457275
    ],
    "tatorte": [
        {
            "lat": 49.00408,
            "lng": 2.56228,
            "data": {
                "title":"my title",
                "subline":"my sublime",
                "teaser":"my teaser text"
            }
        }
    ]
}
因此,我尝试在jQuery中加载和操作JSON,如下所示:

function loadData(){
    var markers = [];
    $.ajax({
        url:'my-json-load.php',
        success:function(data){
            var markers = [];
            $.each(data, function(key, val){
            var position = [val.lat, val.lng];
            markers.push({ latLng: position });
            });
            display(data.center, data.tatorte);
        }
    });
}
然后,要使用Gmap3插件显示它们:

$(function(){
    loadData();
});

function display(center, tatorte) {
    $('#map_canvas').gmap3({
        map:{
            options:{
                center: center,
                zoom:7,
                mapTypeId: google.maps.MapTypeId.TERRAIN
            }
        },
        marker: {
            values: tatorte
        }
    });
}
中心点显示正确,与地图相同。只有标记丢失了。我错过了一些正确的事情。。。我想这很容易,但我对jQuery/javascript或如何修改MySQL查询以获得正确的标记值格式没有太多经验。任何人非常感谢你的帮助。谢谢。

尝试调整php

while ($locations = $tatorte->fetch_assoc()) {
    $lat = $locations['lat'];
    $lng = $locations['lng'];
    $values = json_encode( array('title' => $locations['title'], 'subline' => $locations['subline'], 'teaser' => $locations['teaser']) );

    $rows[] = array('lat' => $lat, 'lng' => $lng, 'values' => $values);
}

检查浏览器控制台中是否有错误?如果您将
标记
而不是
数据传递给显示方法。tartore
?@user2486495控制台中没有错误。是的,标记在那里!现在,我只需要了解如何在信息窗口中显示值。谢谢。没问题。infowindow有很多例子。如果你发现自己有麻烦,不要犹豫。我也许还能再帮上忙:P