Best practice

Best practice per JS

L'API Maps JavaScript funziona solo con un ambiente ECMAScript e W3C DOM standard. Ciò significa che la modifica o l'override del comportamento delle classi e degli oggetti integrati forniti dal browser potrebbe rendere l'API Maps JavaScript non funzionante. A volte altre librerie possono entrare in conflitto con l'API Maps JavaScript modificando il comportamento del browser in modo che non sia più un ambiente ECMAScript standard. L'API Maps JavaScript non è compatibile con queste librerie.

Librerie note per essere incompatibili con l'API Maps JavaScript:

  • Prototipo: esegue l'override di Array.from() e Element.prototype.remove() in modi non standard.
  • MooTools (versioni precedenti): esegue l'override di Array.from() in modo non standard.
  • DateJS (versioni precedenti): esegue l'override di Date.now() in modo non standard.

A volte è possibile modificare le librerie incompatibili per rimuovere gli override non standard.

Best practice per i CSS

Quando aggiungi o personalizzi una mappa con l'API Maps JavaScript, alcuni stili applicati alla pagina web potrebbero sostituire gli stili di mappa e causare conflitti CSS. Se utilizzi un framework CSS o un componente JavaScript per lo stile, potrebbero essere aggiunti ulteriori conflitti CSS con gli stili di mappa.

I componenti di stile JavaScript e i framework CSS spesso utilizzano una reimpostazione CSS o un normalizzatore per gestire le differenze di rendering tra i browser. I framework spesso usano l'elemento box-sizing per ridimensionare i margini e i bordi degli elementi delle pagine web. In genere ciò comporta la modifica del comportamento predefinito del browser dall'utilizzo di content-box a border-box.

Questo tipo di reimpostazione CSS può causare conflitti CSS con l'API Maps JavaScript perché l'API non supporta le modifiche al foglio di stile dello user agent. Ulteriori conflitti con CSS possono verificarsi se il framework o il componente fa riferimento a classi CSS o elementi DOM dell'API Maps JavaScript.

Per evitare questi conflitti, abbiamo diversi consigli da prendere in considerazione.

Specificità

Il CSS incorporato e collegato viene applicato alla mappa prima dello stile di Google Maps. Se tutti gli stili di pagina sono definiti in CSS incorporati o collegati, segui le regole di specificità per assicurarti che alla mappa vengano applicati gli stili corretti.

Elementi CSS comuni, come img, button e a, possono essere sovrascritti dagli stili della pagina. Uno degli scenari più comuni è quando l'attributo max-width dell'elemento img è impostato sul 100%. Di conseguenza, i componenti della mappa potrebbero essere distorti o nascosti, soprattutto se utilizzi InfoWindow.

Per risolvere il problema, puoi aggiornare l'elemento img per la mappa in modo che l'attributo max-width sia impostato su none. Ad esempio:

#map img
{
    max-width : none;
}

Nomi classe

Non fare riferimento a nomi di classi ed elementi DOM interni dell'API JavaScript Maps. Questa operazione non è supportata e può causare modifiche che provocano un errore nel tuo sito web senza preavviso. Ti consigliamo invece di creare le tue classi CSS come container per la mappa.

Se un framework CSS o un componente JavaScript utilizza questo tipo di riferimenti, il suggerimento sull'override delle dimensioni del riquadro potrebbe essere una soluzione.

Sostituzione delle dimensioni dei riquadri CSS

Le sostituzioni delle dimensioni dei riquadri CSS forniscono una possibile soluzione per i conflitti di stile delle mappe. Ciò può essere particolarmente utile se utilizzi un framework CSS o un componente di stile JavaScript. Ad esempio, se box-sizing è impostato su border-box, prova quanto segue:

  • Crea un override box-sizing che imposti l'elemento <html> su border-box.
  • Utilizza box-sizing: inherit per tutti gli elementi diversi dalla mappa.
  • Crea un container di mappe personalizzato che reimposti l'elemento box-sizing su initial.

Esempio di CSS:

html {
  box-sizing: border-box;
}

*,
*::before,
*::after {
  box-sizing: inherit;
}

.container-map {
  box-sizing: initial;
}