PhoneGap谷歌地图 - 地图无法显示

4

我正在编写一个使用PhoneGap的应用程序,并需要将Google Maps集成到其中。我使用了Google提供的在线文档中的示例:

   <!DOCTYPE html>
<html>
  <head>
    <meta name="viewport" content="initial-scale=1.0, user-scalable=no" />
    <style type="text/css">
      html { height: 100% }
      body { height: 100%; margin: 0; padding: 0 }
      #map_canvas { height: 100% }
    </style>
    <script type="text/javascript"
      src="https://maps.googleapis.com/maps/api/js?key=AIzaSyDlFl3vPEbgzrr-1KX5E20z_1DowB2ASus&sensor=true">
    </script>
    <script type="text/javascript">
      function initialize() {
        var mapOptions = {
          center: new google.maps.LatLng(-34.397, 150.644),
          zoom: 8,
          mapTypeId: google.maps.MapTypeId.ROADMAP
        };
        var map = new google.maps.Map(document.getElementById("map_canvas"),
            mapOptions);
      }
    </script>
  </head>
  <body onload="initialize()">
    <div id="map_canvas" style="width:100%; height:100%"></div>
  </body>
</html>

如果我在网页浏览器(Chrome、FF、IE等)中打开它,它可以正常工作。然而,在我的模拟器(和设备)上,它只显示一个空白页面。有什么建议吗?

你的模拟器(和设备)版本是什么? - Palani Kumar
我刚刚复制了上面的代码并通过build.phonegap.com发送了它,然后在Android 2.3.4设备上获得了一个可工作的谷歌地图。 我建议将html和body的width属性设置为100%,这只是一个猜测。 - Dawson Loudon
谢谢大家,我已经解决了这个问题。问题是我有多个HTML页面,而这个脚本在第二个页面上。因此脚本没有执行。 - user10901
1个回答

6

这个问题是因为我在同一个应用程序上使用了多个HTML页面。由于phonegap将使用ajax调用来替换index页面的dom,它无法加载这些页面上的脚本。

这里有两个解决方案:

  1. 只使用一个HTML页面
  2. 使用

    rel="external"

    加载第二个页面


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接