Migrazione: modulo Maps in google.load

Il 13 ottobre 2021 disattiveremo il servizio che fornisce il modulo "Maps" per google.load. Ciò significa che dopo il 13 ottobre 2021, se provi a utilizzare il modulo "Maps" in google.load riceverai un errore (il modulo "maps" non è supportato) e non verrà caricata alcuna mappa. Per evitare potenziali interruzioni, devi passare a una delle alternative.

Che cosa devo fare?

Innanzitutto, rimuovi il tag <script> che carica il caricatore google.load, poi rimuovi le chiamate a google.load. Se utilizzi Google Loader per altre operazioni, puoi lasciare il tag <script> del caricatore.

Successivamente, implementa un nuovo modo per caricare l'API Maps JavaScript (seleziona una delle seguenti opzioni):

Esempio attuale che utilizza Google Loader

L'esempio seguente mostra come viene attualmente utilizzato Google Loader per caricare l'API Maps JavaScript (sono presenti due blocchi <script>):

Prima

<script type='text/javascript' src='https://www.google.com/jsapi'></script>
<script type='text/javascript'>
google.load("maps", "3.exp", {
    "callback": initMap,
    "key": "YOUR_KEY",
    "libraries": "places,visualization"
});
function initMap() {
  // Google Maps JS API is loaded and available
}
</script>

Quando viene utilizzato questo approccio, l'API Maps JavaScript viene caricata contemporaneamente al caricamento della pagina. Per implementare il caricamento in linea, sostituisci innanzitutto il tag <script> che carica www.google.com/jsapi ("before") con il tag <script> mostrato nell'esempio seguente:

<script async src="https://maps.googleapis.com/maps/api/js?libraries=places,visualization&key=YOUR_API_KEY&v=weekly&callback=initMap">
</script>

Poi, nel codice JavaScript, rimuovi la chiamata alla funzione google.load, poiché non è più necessaria. L'esempio seguente mostra una funzione initMap() vuota, che viene chiamata quando la libreria Maps è stata caricata correttamente:

<script type='text/javascript'>
function initMap() {
  // Google Maps JS API is loaded and available
}
</script>

Consulta la documentazione

Caricamento dinamico da un altro file JavaScript

Il caricamento dinamico ti consente di controllare quando viene caricata l'API Maps JavaScript. Ad esempio, puoi attendere di caricare l'API Maps JavaScript finché l'utente non fa clic su un pulsante o esegue un'altra azione. Per implementare il caricamento dinamico, sostituisci prima il tag <script> che carica www.google.com/jsapi ("prima") con il codice per aggiungere il tag <script> in modo programmatico, come mostrato nell'esempio seguente:

var script = document.createElement('script');
script.src =
'https://maps.googleapis.com/maps/api/js?libraries=places,visualization&key=YOUR_API_KEY&v=weekly&callback=initMap';
script.async=true;

Quindi, collega la funzione di callback all'oggetto finestra nel seguente modo:

window.initMap = function() {
  // Google Maps JS API is loaded and available
};

Infine, aggiungi il tag <script> all'intestazione della pagina in questo modo:

document.head.appendChild(script);

Consulta la documentazione