@css19/core
v0.1.13
Published
CSS19 - React CSS prop
Downloads
43
Readme
@css19/core
Intall
npm install @css19/core
NOTE! Requires React 19
Configure
tsconfig.json
{
"compilerOptions": {
"jsxImportSource": "@css19/core"
}
}
Usage
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 "@css19/core";
const headerCss = css({
color: "tomato",
});
function App() {
return (
<div
css={{
// TypeScript currently does not infer the coercion that happens here. Use
// toString(), [`${headerCss}`] or [String(headerCss)] to make TypeScript happy
[headerCss.toString()]: {
fontSize: "48px",
color: "royalblue",
},
}}
>
<h1 css={headerCss}>Hello World</h1>
</div>
);
}
You can also define global css using globalCss
, which returns a style element you need to mount.
import { globalCss } from "@css19/core";
const globalStyle = globalCss({
"@keyframes fade": {
from: { color: "red" },
to: { color: "blue" },
},
});
function App() {
return (
<>
{globalStyle}
<div>
<h1>Hello World</h1>
</div>
<>
)
}
You can also define scoped css using scopedCss
which gives you the className and related style tag. This is useful when you need to use 3rd party components that does not expose usage of the css
prop.
import { scopedCss } from "@css19/core";
const [className, style] = scopedCss({
color: 'red'
});
function App() {
return (
<>
{style}
<SomeExternalComponent className={className} />
<>
)
}
How it works
When the css
prop is active on an element @css19/core
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.