Baseline 2023

Baseline is coming to caniuse.com! In this post learn about the integration, and also discover some of the features that became part of Baseline in 2023.

With the new definition of Baseline, there are two stages in a feature's lifecycle. Firstly, when it becomes newly available, and then when it becomes widely available after 30 months. A feature becomes part of Baseline newly available when it becomes interoperable in the following browsers:

  • Safari (macOS and iOS)
  • Firefox (desktop and Android)
  • Chrome (desktop and Android)
  • Edge (desktop)

Baseline lands on Can I Use

As the next step in clarifying feature availability, Baseline is beginning to land on Can I Use from today. When visiting some pages on Can I Use, you'll see a badge telling you whether the feature is in Baseline widely available.

Screenshot of Can I Use with the widely available badge on CSS Grid Layout.

Features that are in Baseline newly available will also show a badge, along with the year that they became available. So, anything that became interoperable across the core browser set this year is part of Baseline 2023.

Screenshot of Can I Use with the newly available badge on Container Queries.

In the rest of this post, find out about the features that hit this milestone during 2023. All of these features are Baseline 2023—newly available.

Size container queries and container query units

Size container queries let you query the size of an element, in much the same way that media queries let you query the size of the viewport. They make creating reusable components much easier, as you can create components that react to the size of the area they are placed in.

Browser Support

  • 105
  • 105
  • 110
  • 16

Source

The design of the following card changes depending on the width of the component. Learn more in Container queries land in stable browsers.

New color spaces and functions

CSS now supports color spaces that allow you to access colors outside of the sRGB gamut. This means that you can support HD (high definition) displays, using colors from HD gamuts.

New color models

Now in Baseline, the color functions lch(), lab(), oklch(), and oklab() give access to the LCH, Lab, OKLCH, and OKLab color models.

Browser Support

  • 111
  • 111
  • 113
  • 15

Source

A screenshot of the gradient.style editor with a pink to blue vibrant gradient.
Try out the new color spaces using gradient.style.

The color-mix() function

In addition, new color functions have become part of Baseline. The color-mix() function enables mixing of one color into another, in any of the color spaces. In the following CSS, 25% of blue is mixed into white, in the srgb color space.

.example {
  background-color: color-mix(in srgb, blue 25%, white);
}

Browser Support

  • 111
  • 111
  • 113
  • 15

Source

Learn more about color-mix().

The color() function

The color() function can be used for any color space that specifies colors with R, G and B channels. color() takes a color space parameter first, then a series of channel values for RGB and optionally some alpha. You can use any of: srgb, srgb-linear, display-p3, a98-rgb, prophoto-rgb, rec2020, xyz, xyz-d50, and xyz-d65. For example:

.valid-css-color-function-colors {
  --srgb: color(srgb 1 1 1);
  --srgb-linear: color(srgb-linear 100% 100% 100% / 50%);
  --display-p3: color(display-p3 1 1 1);
  --rec2020: color(rec2020 0 0 0);
  --a98-rgb: color(a98-rgb 1 1 1 / 25%);
  --prophoto: color(prophoto-rgb 0% 0% 0%);
  --xyz: color(xyz 1 1 1);
}

The CSS high definition color guide gives you many more examples of the new color spaces and functions, along with information about which to use when.

Compression streams

The Compression Streams API is a JavaScript API for compressing and decompressing streams of data. By using this built-in compression, applications no longer need to include a compression library.

Browser Support

  • 80
  • 80
  • 113
  • 16.4

Source

Learn more in Compression streams are now supported in all browsers.

Offscreen canvas

Before OffscreenCanvas, canvas drawing capabilities were tied to the <canvas> element, which meant it was directly depending on the DOM. OffscreenCanvas, as the name implies, decouples the DOM and the Canvas API by moving it off-screen.

Thanks to this decoupling, rendering of OffscreenCanvas is fully detached from the DOM and therefore offers some speed improvements over the regular canvas as there is no synchronization between the two. What is more, though, is that it can be used to move rendering work to a Web Worker, even though there is no DOM available, freeing the main thread and making the application more responsive.

Browser Support

  • 69
  • 79
  • 105
  • 16.4

Source

Learn more in OffscreenCanvas—speed up your canvas operations with a web worker

Module preload

Preloading modules can reduce download and processing time. Add rel="modulepreload" to the link element referencing a JavaScript module, and the browser gets the module, parses and compiles it, and puts the results into the module map ready to execute.

Browser Support

  • 66
  • ≤79
  • 115
  • 17

Source

Learn more in the article Preload modules.

Trigonometric functions in CSS

In 2023 trigonometric functions from the CSS Values and Units Level 4 specification became interoperable. This means that the functions sin(), cos(), tan(), asin(), acos(), atan(), and atan2() are part of Baseline 2023.

Browser Support

  • 111
  • 111
  • 108
  • 15.4

Source

This demo uses the trigonometric functions to move items on a circular path round a central point.

Learn how to use these functions, and discover some use cases in Trigonometric functions in CSS.

The inert attribute

Inert means lacking the ability to move, so when you mark something inert, you remove movement or interaction from those DOM elements. The inert attribute causes the browser to ignore the element.

  • The click event does not fire if a user clicks on the element.
  • The element won't gain focus.
  • The element and its content is excluded from the accessibility tree.

Browser Support

  • 102
  • 102
  • 112
  • 15.5

Source

This attribute should be added to elements that are offscreen or otherwise hidden. You can learn more in The inert attribute.

Subgrid in CSS grid layout

The subgrid value for grid-template-columns and grid-template-rows lets you use the tracks defined on a parent grid, on nested grids. This means that you can align elements inside these nested grids with each other.

Browser Support

  • 117
  • 117
  • 71
  • 16

Source

In the article CSS subgrid you will find some examples and links to many other posts and examples highlighting subgrid use cases.

NumberFormat V3

Intl.NumberFormat V3 is a set of new features for Intl.NumberFormat, that became part of Baseline during 2023. The additional features are:

  • Three new functions to format ranges of numbers: formatRange, formatRangeToParts, and selectRange.
  • Grouping enum
  • New rounding and precision options
  • Rounding priority
  • Interpret strings as decimals
  • Rounding modes
  • Sign display negative

Browser Support

  • 106
  • 106
  • 116
  • 15.4

Source

The proposal for NumberFormat V3 details each of the new features.

The Fullscreen API

The Fullscreen API lets you place an element, such as a <video> into fullscreen mode, by calling the requestFullscreen() method. It also provides methods for detecting if an element is in fullscreen mode, and whether the document is in a state that will let you request fullscreen mode.

Browser Support

  • 71
  • 79
  • 64
  • 16.4

Source

Learn more in this Guide to the Fullscreen API on MDN.

The CSS :has() selector

Just making Baseline 2023 is the :has() selector, which will land in Firefox 121 on the 19th of December. Among other uses, this selector acts as a parent selector, letting you select an element based on things that are inside it. For example, you can apply different CSS depending on whether there is an image inside an element or not.

Browser Support

  • 105
  • 105
  • 121
  • 15.4

Source

Find out more in :has(): the family selector.

More features that joined Baseline this year

This post has shared some of the key features that became part of Baseline this year, but there's more.

Many of these features reached interoperability through the collaborative work on Interop 2023. It's exciting to see how features can be brought through that process, and land in Baseline as newly available, which sets off the timer for them to become widely available. This creates a clearer path for decisions on when to adopt features in your own projects.