用于谷歌地图信息窗口的PHP XML

用于谷歌地图信息窗口的PHP XML,php,ajax,wordpress,google-maps-api-3,Php,Ajax,Wordpress,Google Maps Api 3,我想做的是从我的谷歌地图中获取以下信息。我知道JavaScript是客户端,而不是像PHP那样的服务器端,所以它在运行JS之前就已经加载了。问题是,如果我严格地通过PHP->XML->JS将post_id列调用到PHP中,它将不会加载链接。有没有一种方法可以做到这一点,只需使用PHP,并让它从markers表中为地图上的每个位置标记提取locations post_id?我也读过关于AJAX的文章,但是我对AJAX的知识不多 boxText.innerHTML = "<div class=

我想做的是从我的谷歌地图中获取以下信息。我知道JavaScript是客户端,而不是像PHP那样的服务器端,所以它在运行JS之前就已经加载了。问题是,如果我严格地通过PHP->XML->JS将post_id列调用到PHP中,它将不会加载链接。有没有一种方法可以做到这一点,只需使用PHP,并让它从markers表中为地图上的每个位置标记提取locations post_id?我也读过关于AJAX的文章,但是我对AJAX的知识不多

boxText.innerHTML = "<div class='mapname'>" + '<a href="<?php echo get_permalink( $post_id ); ?>">' + name + '</a>' + "</div><i>" + listtype + "</i> <br/>" + address + "<br/>" + phone;
boxText.innerHTML=“+++”+列表类型+“
”+地址+“
”+电话;

谢谢

下面是一个完整的PHP Javascript AJAX示例。只需使用名称保存文件 “myServerScript.php”并将浏览器指向它。PHP打印javascript,javascript通过AJAX调用相同的PHP脚本,PHP响应,javascript处理响应

确保您的PHP安装配置为接受短分隔符


很抱歉耽搁了,我仍在努力使用它,我会让你知道的!
<?

if(isset($_GET['msg'])){
    print "alert('AJAX response from PHP - Javascript said:". $_GET['msg']."')";
}
else{
    print <<<qq
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>

<title>AJAX Example: (by Marcelo)</title>
<script src="http://maps.google.com/maps/api/js?sensor=false"></script>


<script>
// Sorry, I can't be bothered typing "google.maps." every time. ;-)
var G = google.maps;

var zoom = 4;
var centerPoint = new G.LatLng(40.178873, -96.767578);
var container;
var map;


function ajaxLoad(url,callback,plain) {
    var http_request = false;

    if (window.XMLHttpRequest) { // Mozilla, Safari, ...
        http_request = new XMLHttpRequest();
        if (http_request.overrideMimeType && plain) {
            http_request.overrideMimeType('text/plain');
        }
    } else if (window.ActiveXObject) { // IE
        try {
            http_request = new ActiveXObject("Msxml2.XMLHTTP");
        } catch (e) {
            try {
                http_request = new ActiveXObject("Microsoft.XMLHTTP");
            } catch (e) {}
        }
    }
    if (!http_request) {
        alert('Giving up :( Cannot create an XMLHTTP instance');
        return false;
    }
    http_request.onreadystatechange =  function() {
        if (http_request.readyState == 4) {
            if (http_request.status == 200) {
                eval(callback(http_request));
            }
            else {
                alert('Request Failed: ' + http_request.status);
            }
        }
    };
    http_request.open('GET', url, true);
    http_request.send(null);
}
var url = "myServerScript.php?msg=hello from javascrpt";
ajaxLoad(url, parseResults, true);


function parseResults(req){
    var text = req.responseText;
    eval(text);
}

function load() {
    container = document.getElementById('mapDiv');

    var myOptions = {
        zoom: zoom,
        center: centerPoint,
        mapTypeId: G.MapTypeId.ROADMAP,
        rotateControl: true,
        keyboardShortcuts:false
    }
    map = new G.Map(container, myOptions);
 google.maps.event.addListener(map,'click',function(mev){
var url = "myServerScript.php?msg="+mev.latLng;
ajaxLoad(url, parseResults, true);    
  });
}

window.onload = load;

</script>
</head>
<body>
Hello from PHP.
<h2>Click on the map to send the lat/lon to PHP</h2>
<div id="mapDiv" style="width: 800px; height: 450px;"></div>
</body>
</html>

qq;

}


?>