[英]Map not loading into HTML page
我有一個要加載到HTML頁面的地圖,該地圖的文件位於app文件夾中,但不加載。 這是插入地圖的地方的代碼
<!-- Contact section start -->
<div id="contact" class="contact">
<div class="section ">
<div class="container">
<div class="title">
<h1>Contact Us</h1>
<p>Duis mollis placerat quam, eget laoreet tellus tempor eu. Quisque dapibus in purus in dignissim.</p>
</div>
</div>
<div class="map-wrapper">
<div class="map-canvas" id="map-canvas">Loading map...</div>
<div class="container">
<div class="row-fluid">
<div class="span5 contact-form centered">
<h3>Say Hello</h3>
<div id="successSend" class="alert alert-success invisible">
<strong>Well done!</strong>Your message has been sent.</div>
<div id="errorSend" class="alert alert-error invisible">There was an error.</div>
<form id="contact-form" action="php/mail.php">
<div class="control-group">
<div class="controls">
<input class="span12" type="text" id="name" name="name" placeholder="* Your name..." />
<div class="error left-align" id="err-name">Please enter name.</div>
</div>
</div>
<div class="control-group">
<div class="controls">
<input class="span12" type="email" name="email" id="email" placeholder="* Your email..." />
<div class="error left-align" id="err-email">Please enter valid email adress.</div>
</div>
</div>
<div class="control-group">
<div class="controls">
<textarea class="span12" name="comment" id="comment" placeholder="* Comments..."></textarea>
<div class="error left-align" id="err-comment">Please enter your comment.</div>
</div>
</div>
<div class="control-group">
<div class="controls">
<button id="send-mail" class="message-btn">Send message</button>
</div>
</div>
</form>
</div>
</div>
</div>
</div>
<div class="container">
<div class="span9 center contact-info">
<p style="color:black;">123 Fifth Avenue, 12th,Belgrade,SRB 11000</p>
<p class="info-mail">ourstudio@somemail.com</p>
<p style="color:black;">+11 234 567 890</p>
<p style="color:black;">+11 286 543 850</p>
</div>
</div>
</div>
</div>
<!-- Contact section edn -->
這是js文件,其中包含加載地圖所需的所有代碼。
//Initialize google map for contact setion with your location.
function initializeMap() {
var lat = '44.8164056'; //Set your latitude.
var lon = '20.46090424'; //Set your longitude.
var centerLon = lon - 0.0105;
var myOptions = {
scrollwheel: false,
draggable: false,
disableDefaultUI: true,
center: new google.maps.LatLng(lat, centerLon),
zoom: 15,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
//Bind map to elemet with id map-canvas
var map = new google.maps.Map(document.getElementById('map-canvas'), myOptions);
var marker = new google.maps.Marker({
map: map,
position: new google.maps.LatLng(lat, lon),
});
var infowindow = new google.maps.InfoWindow();
google.maps.event.addListener(marker, 'click', function () {
infowindow.open(map, marker);
});
infowindow.open(map, marker);
google.maps.event.addDomListener(window, 'load', initializeMap);
}
我看到其他人也遇到類似的問題,但他們通過在標記區域中鍵入optimized:false來解決了這個問題,但對我來說仍然無法正常工作。
您有兩個問題:
您調用google.maps.event.addDomListener(window, 'load', initializeMap);
在 initializeMap()
本身內部 -那么自然就不會初始化地圖。
您需要在#map-canvas
上設置一些尺寸; 即使不是問題#1,也永遠不會顯示地圖。
糾正了這兩個問題后,它就可以工作-> http://jsfiddle.net/1fdzz7gv/
小提琴的代碼與OP中的代碼完全相同,只是google.maps.event.addDomListener(window, 'load', initializeMap);
放置在initializeMap()
外部,並已為#map-canvas
提供了一些尺寸
#map-canvas {
width: 300px;
height: 200px;
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.