Skip to content
Products
Solutions
By industry
By use case
Resources
Products
Solutions
By industry
By use case
Resources
Products
Solutions
By industry
By use case
Resources
Build maps faster with Web Components
2880x1200.max-2600x2600.png
Andrew Mackowski
Software Engineer, Google Maps Platform
Chris J. Shull
Google Maps Platform Tech Lead, Maps JavaScript API
May 10, 2023
Try Google Maps Platform
Unlock access to real-world data and insights with a monthly $200 Google Maps Platform credit.
Get started

Starting today, we're happy to offer Web Components in Preview as a new way for developers to use Google Maps Platform. Initially you’ll be able to access Web Components for Map and Advanced Marker functionality, and we’ll iteratively add more functionality over time. Additionally, we’re also launching an open source Extended Component Library that contains higher level components–like visual representations of Places data,  which will encapsulate best practices, common UI/UX patterns, responsiveness, and accessibility beyond what Maps JavaScript API does out-of-the-box.

Web Components are a popular W3C standard that allows developers to encapsulate HTML, CSS, and JS into a custom and reusable HTML element. These reusable components can range from atomic pieces of functionality–like displaying the star rating for a place–to much more complex business logic. Web Components are easily interoperable with any JS Framework for a lower learning curve, simpler code, and increased readability that helps developers move faster. 

Maps JavaScript API Web Components

Developers can access Map and Advanced Marker Web Components directly from the Maps JavaScript API. They are an easy and quick way for developers to integrate these UI features with little to no JavaScript. Just make sure you get your Google Maps Platform API key (using advanced markers also requires a map with a map ID) and view the documentation.  

The Map component displays a map on a web page and can have additional map-related elements (e.g. advanced markers) inside the Map component in HTML. You can also change the look and feel of the map using Cloud-based map styling by applying a map ID.

Web Components blog image

A Google map showing a red marker in Mountain View, CA

While Maps JavaScript API Web Components are in Preview, they can be tried out through the beta channel.

<html>
<body>
  <script async
          src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&libraries=maps&v=beta&callback=initMap"></script>
 
  <gmp-map style="height: 500px;"
           center="41.081736,29.009206"
           zoom="10">
  </gmp-map>
 
  <script>
    function initMap() { console.log('Maps JavaScript API loaded.'); }
  </script>
</body>
</html>

HTML code sample

The advanced marker component displays a marker on the map. Add the marker library to the script loader and a map ID to the map element to support the advanced marker.

<script async
        src="https://maps.googleapis.com/maps/api/js?key=YOUR_API_KEY&libraries=maps,marker&v=beta&callback=initMap"></script>
 
<gmp-map style="height: 500px;"
         center="41.081736,29.009206"
         zoom="10"
         map-id="DEMO_MAP_ID">
  <gmp-advanced-marker position="41.081736,29.009206"
                       title="Istanbul"></gmp-advanced-marker>
</gmp-map>

HTML code sample

Open Source Extended Component Library

Google Maps Platform provides some of the best geospatial data, but it can take many lines of complex code required to display that data in well-styled UI elements. With the Extended Component Library for Maps JavaScript API, we set out to give every developer Google-grade building blocks that can be accessed, customized, and composed with only a few lines of HTML. This open source library builds upon the Web Components available from the Maps JavaScript API and reduces boilerplate, encapsulates best practices and common UI/UX patterns, is mobile responsive out-of-the-box, and has global styling tokens which makes it easy to customize every component to look and feel like your brand. It also provides a wide range of additional components for styling, place details, autocomplete, and more.

Web Components update

Using Web Components you can quickly create a beautiful visual representation of a Place

How to show a place overview

Three lines of code can show details about a specific location:

<!-- unpkg.com is not affiliated with Google -->
<script async type="module"
        src="https://unpkg.com/@googlemaps/extended-component-library@~0.1">
</script>
 
<gmpx-api-loader key="YOUR_API_KEY"></gmpx-api-loader>
 
<gmpx-place-overview place="ChIJVVVVnvlHDW0Rwyod-_ddhAw"></gmpx-place-overview>

HTML code sample

To find the ID for a place, you can use the Place ID Finder demo or a Find Place search from the Places API. 

Powerful customization and enhancement capabilities are built into these components. For example, specifying a directions button in the Place Overview component generates a button that will initiate getting directions to the place:

<gmpx-place-overview place="ChIJVVVVnvlHDW0Rwyod-_ddhAw"
                     size="medium">
  <gmpx-place-directions-button slot="action">
    Directions
  </gmpx-place-directions-button>
</gmpx-place-overview>

HTML code sample

Getting started

To get started with the Extended Component Library, check it out on GitHub and npm

We’ll continue to bring new Web Components to you in the future to help you create geospatial web experiences with HTML only. For the latest information and more samples for using Web Components from the Maps JavaScript API, reference the documentation. We can’t wait to see what you build with them.

Clay cityscape
Clay cityscape
Google Maps Platform
Get going with Google Maps Platform