Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/242.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript GoogleMapsV3API链接到infowindow_Javascript_Php_Google Maps_Google Maps Api 3 - Fatal编程技术网

Javascript GoogleMapsV3API链接到infowindow

Javascript GoogleMapsV3API链接到infowindow,javascript,php,google-maps,google-maps-api-3,Javascript,Php,Google Maps,Google Maps Api 3,我正在开发GoogleMapsAPIv3(使用php和mysql),我正在寻找一种通过链接打开信息窗口的解决方案 说明: 我创建了一个带有一些标记(客户)的谷歌地图,并直接从我的数据库在另一个循环中创建了一个列表,我希望能够点击我客户的名字,打开地图上的信息窗口 多亏了@MrUpsidown,我找到了这段代码并对其进行了修改,但它不起作用 客户页面: <div> <? include('phpsqlajax_map_v5.php');?> </div>

我正在开发GoogleMapsAPIv3(使用php和mysql),我正在寻找一种通过链接打开信息窗口的解决方案

说明:

我创建了一个带有一些标记(客户)的谷歌地图,并直接从我的数据库在另一个循环中创建了一个列表,我希望能够点击我客户的名字,打开地图上的信息窗口

多亏了@MrUpsidown,我找到了这段代码并对其进行了修改,但它不起作用

客户页面:

<div>
    <? include('phpsqlajax_map_v5.php');?>
</div>
<div>
    <?
        $reponseENT = $bdd->query('
        SELECT *
        FROM client
        WHERE adresse !=""
        AND archive = "FAUX"
        ');
        while($repE = $reponseENT->fetchObject())
            {
            ?>  
                <p><a><? echo $repE->Nom." ".$repE->departement;?></a></p>
            <?
            }
    ?>
</div>

成功!
我创建了一个包含所有位置的php文件,并创建了一个具有相同条件的循环,以实现精确的侦听

<?php
require("inc/header.php");

$fichier ="location.php";
$ouverture = fopen($fichier, "r" );
$ecriture = fopen($fichier, "w+" );

$reponse = $bdd->query('
SELECT * 
FROM client
WHERE 1
ORDER BY nom
');
while ($donnees = $reponse->fetch())
    {
    $id = $donnees['nument'];
    $rsent = preg_replace("/'/","\'",$donnees['nom']);
    $adresse = preg_replace("/'/","\'",$donnees['adresse']);
    $lat = $donnees['lat'];
    $lng = $donnees['lng'];
    $type = $donnees['type'];
    $location= "
        ['<a href=\"reporting_client.php?client=".$id."\">".$rsent."</a>                
        <br/>".$adresse."', ".$lat.", ".$lng."],\n
        ";
        fwrite($ecriture,$location);
    }
fclose($ouverture);
fclose($ecriture);
?>

<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&sensor=false"></script>
<script type="text/javascript">
    var markers = [];
    function initialize() {

        var mapOptions = {
            zoom: 10,
            center: new google.maps.LatLng(40.714364, -74.005972),
            mapTypeId: google.maps.MapTypeId.ROADMAP
        }
        var map = new google.maps.Map(document.getElementById("googlemap"), mapOptions);


        var locations = [
          <? include('location.php');?>  
        ];

        var marker, i;
        var infowindow = new google.maps.InfoWindow();


        google.maps.event.addListener(map, 'click', function() {
            infowindow.close();
        });

        for (i = 0; i < locations.length; i++) {
            marker = new google.maps.Marker({
                position: new google.maps.LatLng(locations[i][1], locations[i][2]),
                map: map,
                icon: locations[i][3]
            });

            google.maps.event.addListener(marker, 'click', (function(marker, i) {
                return function() {
                    infowindow.setContent(locations[i][0]);
                    infowindow.open(map, marker);
                }
            })(marker, i));

            markers.push(marker);
        }

    }
    google.maps.event.addDomListener(window, 'load', initialize);

    function myClick(id){
        google.maps.event.trigger(markers[id], 'click');
    }
</script>
<div id="googlemap" style="width: 100%; height: 500px;"></div>
<? 
$i=0;
$reponseNOM = $bdd->query('
SELECT * 
FROM client
WHERE 1
ORDER BY nom
');
while ($donneesNOM = $reponseNOM->fetch())
    {
    ?>
        <a href="#" onclick="myClick(<? echo $i;$i++?>);"><? echo $donneesNOM['nom'];?></a><br/>
    <?
    }
?>

我的2美分可能重复:避免使用XML,使用JSON表示法。谢谢你的建议,我编辑了我的帖子,artjom B.清理了它。我希望有人能帮助我
<?php
require("inc/header.php");

function parseToXML($htmlStr)
{
$xmlStr=str_replace('<','&lt;',$htmlStr);
$xmlStr=str_replace('>','&gt;',$xmlStr);
$xmlStr=str_replace('"','&quot;',$xmlStr);
$xmlStr=str_replace("'",'&#39;',$xmlStr);
$xmlStr=str_replace("&",'&amp;',$xmlStr);
$xmlStr=str_replace("é",'&eacute;',$xmlStr);
$xmlStr=str_replace("è",'&egrave;',$xmlStr);
$xmlStr=str_replace("à",'&agrave;',$xmlStr);
return $xmlStr;
}

// Connexion à la base de données
$connection=mysql_connect ($host, $username, $password);
if (!$connection) {
  die('Not connected : ' . mysql_error());
}

// Vérification de la connexion
$db_selected = mysql_select_db($database, $connection);
if (!$db_selected) {
  die ('Can\'t use db : ' . mysql_error());
}

// Commande sql de sélection
$query = "
SELECT * 
FROM markers 
WHERE 1
";
$result = mysql_query($query);
if (!$result) {
  die('Invalid query: ' . mysql_error());
}

header("Content-type: text/xml");
// Start XML file, echo parent node
echo '<markers>';

// Iterate through the rows, printing XML nodes for each
while ($row = @mysql_fetch_assoc($result)){
  // ADD TO XML DOCUMENT NODE
  echo '<marker ';
  echo 'name="' . parseToXML($row['name']) . '" ';
  echo 'address="' . parseToXML($row['address']) . '" ';
  echo 'nument="' . $row['nument'] . '" ';
  echo 'lat="' . $row['lat'] . '" ';
  echo 'lng="' . $row['lng'] . '" ';
  echo 'type="' . $row['type'] . '" ';
  echo '/>';
}

// End XML file
echo '</markers>';

?>
<?php
require("inc/header.php");

$fichier ="location.php";
$ouverture = fopen($fichier, "r" );
$ecriture = fopen($fichier, "w+" );

$reponse = $bdd->query('
SELECT * 
FROM client
WHERE 1
ORDER BY nom
');
while ($donnees = $reponse->fetch())
    {
    $id = $donnees['nument'];
    $rsent = preg_replace("/'/","\'",$donnees['nom']);
    $adresse = preg_replace("/'/","\'",$donnees['adresse']);
    $lat = $donnees['lat'];
    $lng = $donnees['lng'];
    $type = $donnees['type'];
    $location= "
        ['<a href=\"reporting_client.php?client=".$id."\">".$rsent."</a>                
        <br/>".$adresse."', ".$lat.", ".$lng."],\n
        ";
        fwrite($ecriture,$location);
    }
fclose($ouverture);
fclose($ecriture);
?>

<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&sensor=false"></script>
<script type="text/javascript">
    var markers = [];
    function initialize() {

        var mapOptions = {
            zoom: 10,
            center: new google.maps.LatLng(40.714364, -74.005972),
            mapTypeId: google.maps.MapTypeId.ROADMAP
        }
        var map = new google.maps.Map(document.getElementById("googlemap"), mapOptions);


        var locations = [
          <? include('location.php');?>  
        ];

        var marker, i;
        var infowindow = new google.maps.InfoWindow();


        google.maps.event.addListener(map, 'click', function() {
            infowindow.close();
        });

        for (i = 0; i < locations.length; i++) {
            marker = new google.maps.Marker({
                position: new google.maps.LatLng(locations[i][1], locations[i][2]),
                map: map,
                icon: locations[i][3]
            });

            google.maps.event.addListener(marker, 'click', (function(marker, i) {
                return function() {
                    infowindow.setContent(locations[i][0]);
                    infowindow.open(map, marker);
                }
            })(marker, i));

            markers.push(marker);
        }

    }
    google.maps.event.addDomListener(window, 'load', initialize);

    function myClick(id){
        google.maps.event.trigger(markers[id], 'click');
    }
</script>
<div id="googlemap" style="width: 100%; height: 500px;"></div>
<? 
$i=0;
$reponseNOM = $bdd->query('
SELECT * 
FROM client
WHERE 1
ORDER BY nom
');
while ($donneesNOM = $reponseNOM->fetch())
    {
    ?>
        <a href="#" onclick="myClick(<? echo $i;$i++?>);"><? echo $donneesNOM['nom'];?></a><br/>
    <?
    }
?>