From cec9dca00e68ea4f2cef14fb4ffdad9f6600991e Mon Sep 17 00:00:00 2001 From: Rachel Andrew Date: Mon, 1 Mar 2021 16:55:10 +0000 Subject: [PATCH] Adding the missing CSS Ref Houdini overview --- files/en-us/web/css/css_houdini/index.html | 82 ++++++++++++++++++++++ 1 file changed, 82 insertions(+) create mode 100644 files/en-us/web/css/css_houdini/index.html diff --git a/files/en-us/web/css/css_houdini/index.html b/files/en-us/web/css/css_houdini/index.html new file mode 100644 index 000000000000000..87d90ea869d6f63 --- /dev/null +++ b/files/en-us/web/css/css_houdini/index.html @@ -0,0 +1,82 @@ +--- +title: CSS Houdini +slug: Web/CSS/CSS_Houdini +tags: + - CSS + - Houdini + - Experimental + - Guide + - Overview + - Reference +--- +
{{CSSRef}}
+ +

CSS Houdini is a set of APIs that expose parts of the CSS engine. This makes it easier for developers to create extensions for CSS. These extensions might be to polyfill features that are not yet available in a browser, experiment with new ways of doing layout, or add creative borders or other effects.

+ +

While many Houdini examples showcase the creative possibilities of the APIs, there are many practical use cases. For example, you can use Houdini to create advanced custom properties with type checking and default values.

+ +

Basic example

+ +

A regular CSS custom property consists of a property name and a value. Therefore I might create a custom property called --background-color and expect it to be given a color value. The value is then used in the CSS as if it were the color value.

+ +
:root {
+  --background-color: blue;
+}
+
+.box {
+  background-color: var(--background-color);
+}
+ +

In the above example however, there is nothing to stop someone using some other value for this property, perhaps setting it to a length. Having done so, anywhere that the property is used would have no background color as background-color: 12px is not valid. When browsers come across CSS they don't recognize as valid they throw that line away.

+ +

Using {{cssxref("@property")}} however, we can declare the custom property with a {{CSSxRef("@property/syntax","syntax")}} of <color>. This shows that we need this property to have a value which is a valid color.

+ +
@property --background-color {
+  syntax: '';
+  inherits: false;
+  initial-value: blue;
+}
+ +

Houdini worklets

+ +

A feature of Houdini is the {{domxref("Worklet")}}. A worklet is a module, written in JavaScript, that extends CSS using one of the Houdini APIs. You can see an example worklet on the {{domxref("PaintWorklet.registerPaint()")}} page. Once a worklet has been registered you can use it in CSS just like any other value. This means that even if you are not a JavaScript developer, you can access Houdini APIs by using worklets other people have created.

+ +

The Houdini.how website has a number of worklets that you can try on your own site.

+ +

Reference

+ +

CSS at-rule and descriptors

+ +

The {{CSSxRef("@property")}} at-rule allows you to register an advanced custom property.

+ + + +

Houdini API references

+ + + +

Houdini guides

+ + + +

External resources

+ +