我不知道为什么当我尝试在我的应用程序上显示地图时它不起作用..只是灰色,但是当我在Jsfiddle上运行时,一切都很好。我认为这是关于页面显示,如果我将其更改为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');
});
,第二件事是标题标记没有显示出来。请帮忙..谢谢
答案 0 :(得分:0)
触发调整大小事件后重置地图的中心位置。
$( document ).bind( "pageshow", function( event, data ){
google.maps.event.trigger(map, 'resize');
map.setCenter(currentPositionMarker.getPosition());
});
(将currentPositionMarker
全局变为全局map
变量后)