Avant de répondre: ce n'est pas aussi droit que vous attendez!jquery: comment charger l'API Google Maps via ajax?
- J'ai un « afficher sur la carte » bouton qui quand on clique dessus ouvre une DialogBox/lightbox avec la carte Google dans.
- Je ne veux pas charger le api de cartes sur pageload, juste quand une carte a été demandé
C'est un fichier php sur le bouton « afficher sur la carte » met dans la boîte de dialogue:
<div id="map_canvas"></div>
<script type="text/javascript">
$(function() {
//google maps stuff
var latlng = new google.maps.LatLng(<?php echo $coords ?>);
var options = {
zoom: 14,
center: latlng,
mapTypeControl: false,
mapTypeId: google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById('map_canvas'), options);
var marker = new google.maps.Marker({
position: new google.maps.LatLng(<?php echo $coords ?>),
map: map
});
})
</script>
J'ai essayé de charger l'API avant ajaxing dans la boîte de dialogue comme celui-ci:
$('img.map').click(function(){
var rel = $(this).attr('rel');
$.getScript('http://maps.google.com/maps/api/js?sensor=false', function(){
$.fn.colorbox({
href:rel
})
});
})
cela ne semble pas fonctionner :(
j'ai aussi essayé :
- ajouter
<script src="http://maps.google.com/maps/api/js?sensor=false"></script>
au fichier ajax - type = "text/javascript" en cours d'exécution
$.getScript('http://maps.google.com/maps/api/js?sensor=false');
sur doc.ready
le problème le navigateur semble être redirigé vers le fichier api.js - vous voyez un écran blanc
cool. Ou vous pourriez avoir minimalement modifié votre code original en utilisant getJSON, comme je l'ai indiqué dans ma réponse mise à jour. – Andrew