Leaflet migration guide
This part of the docs is dedicated to the migration from leaflet
to maplibre-gl
.
This guide might not be accurate depending on the current version of leaflet
.
The main differences in term of functionality is the ability to support map rotation, vector tiles and globe. For large datasets MapLibre is faster due to its usage of webgl technology.
Setting Up MapLibre
Install MapLibre GL JS and replace Leaflet with MapLibre in your project:
Initializing the Map
Leaflet
const map = L.map('map').setView([0, 0], 2);
L.tileLayer('https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png', {
attribution: '© OpenStreetMap contributors'
}).addTo(map);
MapLibre
import 'maplibre-gl/dist/maplibre-gl.css';
import {Map} from 'maplibre-gl';
const map = new Map({
container: 'map',
style: 'https://demotiles.maplibre.org/style.json',
center: [0, 0],
zoom: 2
});
Adding a Marker
Leaflet
MapLibre
Adding a GeoJSON Layer
Leaflet
MapLibre
map.on('load', function () {
map.addSource('geojson-source', {
type: 'geojson',
data: 'data.geojson',
});
map.addLayer({
id: 'geojson-layer',
type: 'fill',
source: 'geojson-source',
paint: {
'fill-color': '#0080ff',
'fill-opacity': 0.5,
},
});
});
Handling Click Events
Leaflet
MapLibre
Displaying a Popup
Leaflet
MapLibre
Adding a Custom Tile Layer
Leaflet
MapLibre
map.on('load', function () {
map.addSource('osm', {
type: 'raster',
tiles: ['https://tile.openstreetmap.org/{z}/{x}/{y}.png'],
tileSize: 256
});
map.addLayer({
id: 'osm-layer',
type: 'raster',
source: 'osm',
});
});
Adding a Polygon
Leaflet
MapLibre
map.on('load', function () {
map.addSource('polygon', {
type: 'geojson',
data: {
type: 'Feature',
geometry: {
type: 'Polygon',
coordinates: [[[ -0.1, 51.5 ], [ -0.12, 51.5 ], [ -0.12, 51.52 ], [ -0.1, 51.5 ]]]
}
}
});
map.addLayer({
id: 'polygon-layer',
type: 'fill',
source: 'polygon',
paint: {
'fill-color': '#ff0000',
'fill-opacity': 0.5
}
});
});