ClassName ·
data:image/s3,"s3://crabby-images/69ce8/69ce819c04a454c0ca55a7c85c2da123ab9a65a2" alt="npm bundle size (minified + gzip)"
Tiny helper for building CSS classes with BEM methodology.
Install
npm i -S @bem-react/classname
Usage
import { cn } from '@bem-react/classname';
const cat = cn('Cat');
cat();
cat({ size: 'm' });
cat('Tail');
cat('Tail', { length: 'small' });
const dogPaw = cn('Dog', 'Paw');
dogPaw();
dogPaw({ color: 'black', exists: true });
Configure
By default classname
uses React naming preset. But it's possible to use any.
import { withNaming } from '@bem-react/classname';
const cn = withNaming({ n: 'ns-', e: '__', m: '_', v: '_' });
cn('block', 'elem')({ theme: 'default' });