Feature detect CSS @starting-style support

The other day on Mastodon, Ryan wondered how hey can detect support for @starting-style. While in theory you could use @supports at-rule() for this, in practice you can’t because it has no browser support (😭).

Drawing inspiration from my previous post on how to detect support for @property, I came up with a similar method to detect @starting-style support

~

The Code

The code I landed on is this:

@property --supported {
	syntax: "*";
	initial-value: ;
	inherits: false;
}

:root {
	--supported: initial;
	transition: --supported 0s calc(infinity * 1s) step-end;
	transition-behavior: allow-discrete;
}

@starting-style {
	:root {
		--supported: ;
	}
}

/* Usage: */
:root {
  --bg-if-support: var(--supported) green;
  --bg-if-no-support: var(--supported, red);
}
body { 
  background: var(--bg-if-support, var(--bg-if-no-support));
}

The code uses @starting-style to set up a Space Toggle with the --supported property. In browsers without support the value is initial. You can use the computed value of --supported as a classic Space Toggles but also with Style Queries or other types of conditionals.

~

How it works

The code works by registering a custom property with an initial-value that is not initial. The value of that property gets changed to initial in :root but @starting-style also changesit.

To prevent the value from swapping back to initial, the property is given a transition delay that lasts for all eternity. For this to work, it relies on transition-behavior.

🌟 Shout-out to Schepp who mentioned this “long transition delay”-approach at CSS Day. The idea got stuck in my head and I’m happy I was able to use it shortly after discussing it.

~

Demo

Embedded below is a demo that uses this technique. In browsers with support for @starting-style the background is green, otherwise it will be red.

See the Pen
Detect @starting-style support
by Bramus (@bramus)
on CodePen.

Note that it doesn’t properly detect Chrome versions 117-118 because of the @property bug I detailed in the previous post on feature detecting @property. I think this is acceptable.

~

Alternative Approach: Style Queries

The following demo is a variant that uses Style Queries to respond to the change instead of a Space Toggle. The core mechanism under the hood is still the the same: a transition-delay mechanism on the custom property.

See the Pen Detect @starting-style support by Bramus (@bramus) on CodePen.

Unfortunately, because Style Queries are not widely supported at this moment, the test is incomplete and incorrectly excludes many browser versions because they simply don’t support Style Queries. On the other hand the code is easier to read and understand.

@property --supported {
	syntax: "<number>";
	initial-value: 0;
	inherits: false;
}
:root {
	transition: --supported 0s calc(infinity * 1s);
}
@starting-style {
	:root {
		--supported: 1;
	}
}

~

Published by Bramus!

Bramus is a frontend web developer from Belgium, working as a Chrome Developer Relations Engineer at Google. From the moment he discovered view-source at the age of 14 (way back in 1997), he fell in love with the web and has been tinkering with it ever since (more …)

Unless noted otherwise, the contents of this post are licensed under the Creative Commons Attribution 4.0 License and code samples are licensed under the MIT License

Join the Conversation

3 Comments

    1. Hey Rogier!

      As mentioned in the original post that is because the check relied on Style Queries.

      I had hinted that a Space Toggle would solve this and thanks to you nudge I went ahead and implemented it.

      As a result, I have updated the code+demo to use a Space Toggle instead … which work fine in Safari and Firefox as well 🙂

Leave a comment

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.