我有什么:标记是通过表单提交创建的,表单包含邮政编码输入。下面的javascript将采用此邮政编码并在谷歌地图上显示为标记。(这是一个不同的页面)
page1.php(下面的代码)我有一个php数组,这个数组包含所有infoWindow数据,javascript是创建map,标记和inforwindows。
<?php
..............
$info= array();
foreach($details as $d) {
$info[] = "<div id='infoData'>".$d['name'].$d['quantity']."<button id='details' onclick='window.location.href= '''"page2.php'''"'>Detail</button>"."<div>";
}
//.........
?>
上面的代码是信息窗口上的所有内容。单击产品数组中的该按钮将转到第 2 页.php
<script>
//...................
function init() {
var mapDiv = document.getElementById("map");
var mapOptions = {
center: new google.maps.LatLng(51.528308,-0.3817765),
zoom: 12,
mapTypeId: 'roadmap'
};
var map = new google.maps.Map(mapDiv, mapOptions);
///////////////add markers//////////
var addressArray = ("abc", "def","xxx"), infoArray = (<?php echo $i; ?>);
var geocoder = new google.maps.Geocoder();
for (var i = 0, j=addressArray.length; i < j; i++) {
var info = infoArray[i];
geocoder.geocode({'address': addressArray[i]}, createCallback(info, map));
} //callback function
}
function createCallback(info, map) {
var callback = function(results, status) {
if (status == google.maps.GeocoderStatus.OK) {
var marker = new google.maps.Marker({
map: map,
position: results[0].geometry.location,
title: 'Click for more details'
});
//..................
</script>
我想要实现的目标: page2.php
我想在我刚刚单击infowindow
中显示该page1.php
按钮的更多详细信息。我应该怎么做?任何提示??
我在第二页上写了php代码,但我只是把所有记录都拿出来了,刚刚单击的标记与 Page2 记录之间没有关联。我怎样才能做到这一点?第二页不包含任何地图,只有纯文本数据。
在代码中,您可以传递要在 page2 上显示的该记录的唯一键或 id.php并使用 $_GET
方法获取该 ID 并用于显示该标记的详细信息。
在第 1 页上.php
<?php
..............
$info= array();
foreach($details as $d) {
$info[] = "<div id='infoData'>".$d['name'].$d['quantity']."<button id='details' onclick='window.location.href= '''"page2.php?marker=".$d['id']."'''"'>Detail</button>"."<div>";
}
//.........
?>
在第 2 页上.php
$infomarker = $_GET['marker'];
使用$infomarker
获取所有详细信息。