@css19/css-prop
TypeScript icon, indicating that this package has built-in type declarations

0.1.26 • Public • Published

@css19/css-prop

Intall

npm install @css19/css-prop

NOTE! Requires React 19

Configure

tsconfig.json

{
  "compilerOptions": {
    "jsxImportSource": "@css19/css-prop"
  }
}

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 "@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>
  );
}

How it works

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.

Readme

Keywords

Package Sidebar

Install

npm i @css19/css-prop

Weekly Downloads

1

Version

0.1.26

License

MIT

Unpacked Size

9.98 kB

Total Files

12

Last publish

Collaborators

  • christianalfoni