New Oct 28, 2024

Web Component continued progress

Top Front-end Bloggers All from Brad Frost View Web Component continued progress on bradfrost.com

At Big Medium, we’re fans of Web Components, and over the last 6 years have been helping our clients build standards-based, interoperable, design systems with them. The ability to deliver a consistent, cohesive experience to a any web-based technology perfectly aligns with the aim of a design system:

It’s increasingly common for organizations to have web stuff built in a whole slew of technologies, and at the end of the day we want to deliver high-quality, cohesive user experiences to all of them. Users don’t give a crap if the homepage is powered by Drupal and the post-login dashboard is a React app. They want to get things done and get on with their lives, and our software should help them accomplish their goals with minimum fuss and muss. Design systems are an important tool for accomplishing that.

There have been a few exciting yet somewhat under-the-radar developments that are making Web Components even more awesome.

React 19 supports Web Components

In late April, it was announced that React 19 supports custom elements, finally making Web Components a first-class citizen in the React ecosystem.

React 19 adds full support for custom elements and passes all tests on Custom Elements Everywhere.

In past versions, using Custom Elements in React has been difficult because React treated unrecognized props as attributes rather than properties. In React 19, we’ve added support for properties that works on the client and during SSR…

Over the years, we’ve helped clients create a React-specific wrapper layer around the core Web Components in order to deal with React’s weird handling of events. It’s exciting to think that hopefully someday soon those wrapper libraries can be deprecated.

Better Declarative Shadow DOM support

The other exciting thing is that Declarative Shadow DOM is now well supported across the most popular browser engines.

Declarative Shadow DOM has been around for a while, and is important for making Web Components render on the server. Hopefully now that Declarative Shadow DOM is well supported, server rendering of Web Components can become the default. I’m also hopeful tooling continues to improve so that we can successfully marry a progressive-enhancement default with a solid developer experience.

The Web Component learning curve

Web Component support, compatibility, and tooling continue to make steady progress, which is exciting to see! But like most technology issues, so much has to do with the people side of things. Here’s just a questions that we’re encountering in our work:

The answers to these questions is a coordination of technical architecture, people, and process. That’s our jam! If your team would welcome help establishing or evolving your Web Component architecture, feel free to get in touch!

Scroll to top