我有一个页面,其中有一个嵌入在 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&zoom=18&size=640x640&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&
zoom=18&size=640x640&sensor=false" id="iframe"></iframe>