谷歌地图没有;t在jquery mobile中加载

Google map didn't load in jquery mobile

本文关键字:jquery mobile 加载 谷歌地图      更新时间:2023-09-26

我不知道为什么当我试图在我的应用程序上显示地图时,它不起作用。。只是灰色,但当我在Jsfidle上运行时,一切都很好。我认为这是关于pageshow的,如果我把它改为pageinit,映射就没有完全加载,我已经把所有的高度和宽度都改为100%,但仍然没有完全加载。。

<html lang="en">
  <head>
    <title>Maps</title>
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css" />
    <script src="http://code.jquery.com/jquery-1.11.1.min.js"></script>
    <script src="http://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"></script>
    <script type="text/javascript" src="http://maps.google.com/maps/api/js?v=3&sensor=false&language=en"> </script>
    <script type="text/javascript">

        var map;
        function initialize()
        {
            map = new google.maps.Map(document.getElementById('map_canvas'), {
               zoom: 7,
               center: new google.maps.LatLng(38.0457918, 23.7676337),
               mapTypeId: google.maps.MapTypeId.ROADMAP
             });
            var currentPositionMarker = new google.maps.Marker({
                    position: new google.maps.LatLng(38.0457918, 23.7676337),
                    map: map,
                    title :"hei"
                });
        }

        $(document).on("pageshow", "#basic-map", function() {
            initialize();
        });

    </script>
</head>
<body>
    <div id="basic-map" data-role="page">
        <div data-role="header">
            <h1><a data-ajax="false" href="/">examples</h1>
        </div>
        <div data-role="content"> 
            <p>this is paragraph</p>
              <ul data-role="listview" data-inset="true" data-divider-theme="b">
                  <li data-role="list-divider">Map</li>
                  <div id="map_canvas" style="height:320px;"></div> 
                </ul>
        </div>
    </div>      
</body>
</html>

我确实尝试添加了这段代码,但地图已经完全加载,但标记没有居中。。

$( document ).bind( "pageshow", function( event, data ){
google.maps.event.trigger(map, 'resize');
});

第二件事是标题标记没有出现。请帮忙。。感谢

触发调整大小事件后重置地图的中心位置。

$( document ).bind( "pageshow", function( event, data ){
  google.maps.event.trigger(map, 'resize');
  map.setCenter(currentPositionMarker.getPosition());
});

(在使currentPositionMarkermap变量一样全局之后)