react-map-gl | Docs
React Components Suite for Mapbox GL JS.
In addition to exposing MapboxGL functionality to React apps, react-map-gl also integrates seamlessly with deck.gl.
Using react-map-gl
requires node >= v4
and react >= 15.4
.
npm install --save react-map-gl
import {Component} from 'react';
import ReactMapGL from 'react-map-gl';
class Map extends Component {
state = {
viewport: {
width: 400,
height: 400,
latitude: 37.7577,
longitude: -122.4376,
zoom: 8
}
};
render() {
return (
<ReactMapGL
{...this.state.viewport}
onViewportChange={(viewport) => this.setState({viewport})}
/>
);
}
}
To show maps from a service such as Mapbox you will need to register on their website in order to retrieve an access token required by the map component, which will be used to identify you and start serving up map tiles. The service will be free until a certain level of traffic is exceeded.
There are several ways to provide a token to your app, as showcased in some of the example folders:
- Modify the source directly
- Set the
MapboxAccessToken
environment variable - Provide it in the URL, e.g
?access_token=TOKEN
But we would recommend using something like dotenv and put your key in an untracked .env
file, that will then expose it as a process.env
variable, with much less leaking risks.