To find local or global data for an area, you use the GeoEnrichment service. GeoEnrichment is the process of enhancing (enriching) existing data with additional location-based information about the people and places in a specific area. The enriched data can drive better understanding, analysis, and decision making.
You can build applications that use the service to:
- Find demographics and other relevant characteristics within an area around a point.
- Choose from over 15,000 analysis variables in more than 130 countries and regions including demographics, lifestyle segmentation, consumer spending, and market potential.
- Enrich your own data with location based context about the people and places in an area.
- Analyze markets and consumers, identify underserved communities, and formulate better business and policy decisions.
How to access the GeoEnrichment service
There is no direct integration with the Esri Leaflet plugin to access the GeoEnrichment service. To access the service in your application, you use the demographics
and request
modules from ArcGIS REST JS in addition to the Esri Leaflet plugin.
- Reference the Esri Leaflet plugin.
- Reference the appropriate ArcGIS REST JS package.
- Set the API key to authenticate the request.
- Define parameters to pass to the service.
- Call the service and handle the results.
Example
Find demographic data
This example illustrates how to query demographic data from the GeoEnrichment service using ArcGIS REST JS. The default study area is a one mile buffer around a point. It returns facts from the default data collection, Key global facts.
<script src="https://unpkg.com/esri-leaflet@3.0.12/dist/esri-leaflet.js"></script>
<script src="https://unpkg.com/@esri/arcgis-rest-request@4.0.0/dist/bundled/request.umd.js"></script>
<script src="https://unpkg.com/@esri/arcgis-rest-request@4.0.0/dist/bundled/demographics.umd.min.js"></script>
<script>
arcgisRest.queryDemographicData({
studyAreas: [{ "geometry": { "x": latlng.lng, "y": latlng.lat } }],
authentication: authentication
})
.then((response) => {
console.log(response)
});
</script>