npm install @css19/css-prop
NOTE! Requires React 19
tsconfig.json
{
"compilerOptions": {
"jsxImportSource": "@css19/css-prop"
}
}
The CSS object follows the nested CSS spec. That means any attributes, pseudos etc. needs to use the &
to add it to the actual element consuming the style definition.
function App() {
return (
<div>
<h1
css={{
color: "red",
":hover": {
color: "blue",
},
}}
>
Hello World
</h1>
</div>
);
}
Any element now has a typed css
property where you can use any kind of CSS selector.
You can define style definitions outside components using the css
function. This provides typing and you can use the object as an override reference.
import { css } from "@css/css-prop";
const headerCss = css({
color: "tomato",
});
function App() {
return (
<div
css={{
[headerCss]: {
fontSize: "48px",
color: "royalblue",
},
}}
>
<h1 css={headerCss}>Hello World</h1>
</div>
);
}
When the css
prop is active on an element @css19/css-prop
will create a hash from the object. Order of keys does not matter, if the objects represents the same styling, the hash is the same. By using the new style tag and hoisting feature of React 19, your CSS is will "just work" both client and server side.
Each element gets only a single CSS classname that references the styling generated related to the element. React 19 automatically de-duplicates styles. This ensures no presedence issues and styling for each element will be co located.