0

我有一个页面,其中有一个嵌入在 iFrame 中的 Google 静态地图实例。当页面加载时,这个 iFrame 的初始实例会加载一个设置的位置。页面上有一个地址列表,用户可以单击并根据他们的选择,通过 AJAX 重新加载嵌入了 Google 地图的 iFrame。

我在加载新 URL 时遇到了一些问题。以下是我目前使用的 PHP

$database->mysqlquery("SELECT street_address
                       FROM favorites
                       WHERE id = $row_id");

while($row = mysql_fetch_array($database->results)){
    $address = $row[street_address];
}

$url = "http://maps.googleapis.com/maps/api/staticmap?center=$address&zoom
=18&size=640x640&sensor=false";

我从我的数据库中获取地址并将其分配给一个变量。然后我将变量传递给静态地图 URL。

定义了 url,我调用了一个 iFrame

<iframe width = "425" height = "315" frameborder = "0" scrolling = "no" 
marginheight = "0" marginwidth = "0" src= "<?php echo $url; ?>" id = "iframe"></iframe>

当我直接点击php页面或通过AJAX调用页面时,iFrame不加载。当我使用 Chrome 或 Firefox 检查页面时,我看到以下来源

<iframe width="425" height="315" frameborder="0" scrolling="no" 
marginheight="0" `marginwidth="0" 
src="http://maps.googleapis.com/maps/api/staticmap?center=116 Ponce De Leon Ave 
NE, Atlanta, GA&amp;zoom=18&amp;size=640x640&amp;sensor=false" id="iframe"></iframe>

如果我从上面获取 src 字符串并直接通过浏览器加载链接,则地图会加载。

为什么我的 iFrame 没有加载?

更新

添加 rawurlencode() 以编码 $address 变量后的新 iFrame HTML

<iframe width="425" height="315" frameborder="0" scrolling="no" marginheight="0" 
marginwidth="0" 
src="http://maps.googleapis.com/maps/api/staticmap? 
center=116%20Ponce%20De%20Leon%20Ave%20NE%2C%20Atlanta%2C%20GA&amp;
zoom=18&amp;size=640x640&amp;sensor=false" id="iframe"></iframe>
4

1 回答 1

0

您必须对 street_address 进行编码,例如通过rawurlencode()

URL 中不允许有空格(当您直接在浏览器中使用带空格的 URL 时,它可以工作,因为大多数浏览器会自动对 URL 进行编码)

于 2013-04-13T22:15:02.560 回答