【问题标题】:Why is my google map blank?为什么我的谷歌地图是空白的?
【发布时间】:2011-09-12 09:08:46
【问题描述】:

我以前没有见过这种情况,通常地图要么加载,要么由于某些错误而没有加载。我正在加载地图而没有错误,但它是空白的:

<script type='text/javascript' src='http://maps.google.com/maps/api/js?sensor=false&#038;ver=3.0'></script>
<script type="text/javascript">
  function initialize() {
    var latlng = new google.maps.LatLng(43.9869349, -102.24306);
    var myOptions = {
      zoom: 6,
      center: latlng,
      mapTypeId: google.maps.MapTypeId.TERRAIN
    };
    var map = new google.maps.Map(document.getElementById("map_canvas"),
        myOptions);
  }
    </script>

 <div id="map_canvas" style="width:100%; height:300px"></div>

其他人看到这个或知道可能是罪魁祸首吗?地图本身位于我用 jQuery 显示/隐藏的 div 中。会不会是冲突?

回答

这只是与我定义了 img {display:none} 的父 div 的愚蠢冲突。哎呀。 .感谢大家试图提供帮助。

【问题讨论】:

  • 错误控制台有错误吗?你在哪里打电话initialize()
  • 没有和身体上...很抱歉漏掉了:&lt;body onload="initialize()"&gt;
  • 刚刚将您的代码粘贴到一个 html 文件中,地图对我来说正确显示,您的 html 的其余部分是什么?
  • 如果你使用 jquery,你可能想要这个插件blog.bobcravens.com/2010/06/…
  • @corroded,谢谢,我去看看

标签: javascript google-maps-api-3 maps


【解决方案1】:

尝试添加这个:

window.onload = function(evt) {
    // this is a simple replica of jQuery's ready function
    if(document.readyState === 'complete') {
        var latlng = new google.maps.LatLng(43.9869349, -102.24306);
        var myOptions = {
            zoom: 6,
            center: latlng,
            mapTypeId: google.maps.MapTypeId.TERRAIN
        };
        var map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
    }
}

【讨论】:

  • 谢谢,但我不这么认为,我也在加载 jQuery,我尝试将它包装在 ready 函数中。我也尝试将它加载到 body &lt;body onload="initialize()"&gt;
  • 可能看起来很傻,但是尝试手动访问谷歌地图,也许你的路由器有一些限制等等......
【解决方案2】:

试试这个

<script type='text/javascript' src='http://maps.google.com/maps/api/js?sensor=false&#038;ver=3.0'></script>
<script type="text/javascript">
  function initialize() {
    var latlng = new google.maps.LatLng(43.9869349, -102.24306);
    var myOptions = {
      zoom: 6,
      center: latlng,
      mapTypeId: google.maps.MapTypeId.TERRAIN
    };
    var map = new google.maps.Map(document.getElementById("map_canvas"),
        myOptions);
  }
    </script>

 <div id="map_canvas" style="width:100%; height:300px"></div>
<script>initialize();</script>

【讨论】:

  • 不,我可以在网站的其他部分正常加载
【解决方案3】:

我尝试了 google 的示例,它看起来与您正在做的非常相似,并且效果很好。

http://code.google.com/apis/maps/documentation/javascript/examples/map-simple.html

我怀疑您的 lat/lng 颠倒了,但事实并非如此。也许可以再次完成这个示例 - 因为我只是在本地运行它没有任何问题。

【讨论】:

  • 呸..这是因为我把它放在了.thatDiv img {display: none}