Il 13 ottobre 2021 disattiveremo il servizio che fornisce il modulo "Maps" per google.load
.
Ciò significa che dopo il 13 ottobre 2021, se proverai a utilizzare il modulo "Mappe" in google.load
, riceverai un errore (le "mappe" del modulo non sono supportate) e non verrà caricata nessuna mappa. Per evitare potenziali interruzioni, devi passare a una delle alternative.
Cosa devo fare?
Rimuovi prima il tag <script>
che carica il caricatore google.load
,
quindi rimuovi le chiamate a google.load
. Se utilizzi Google Loader per altre attività, non esitare a lasciare il tag <script>
del caricatore.
Successivamente, implementa un nuovo modo per caricare l'API Maps JavaScript (seleziona una delle seguenti opzioni):
- Caricamento incorporato utilizzando il tag
<script>
- Caricamento dinamico da un altro file JavaScript
Esempio attuale con Google Loader
L'esempio seguente mostra come viene attualmente utilizzato Google Loader per caricare
l'API Maps JavaScript (ci sono 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>
Caricamento in linea utilizzando il tag <script>
(consigliato)
Se viene utilizzato questo approccio, l'API Maps JavaScript viene caricata nello stesso momento in cui viene caricata la pagina. Per implementare il caricamento in linea, sostituisci prima 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 a funzione google.load
, poiché non è più necessaria. L'esempio seguente mostra una funzione initMap()
vuota, che viene richiamata quando la libreria di Maps è stata caricata correttamente:
<script type='text/javascript'>
function initMap() {
// Google Maps JS API is loaded and available
}
</script>
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 ("before") con il codice per aggiungere in modo programmatico il tag <script>
, 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 della finestra in questo 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);