Skip to content
This repository has been archived by the owner on Nov 20, 2022. It is now read-only.
/ purebem-js Public archive

A BEM CSS methodology utility helper

License

Notifications You must be signed in to change notification settings

gravplats/purebem-js

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

25 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

purebem-js

A BEM CSS methodology utility helper

npm version

A simple JavaScript utility for creating BEM standard CSS class names. This is a stricter cousin of purebem.

Install

To install the stable version:

npm install --save purebem-js

Usage

Import module

import purebem from 'purebem-js';

const element = purebem('my-block');

// Define a block.
block();
// 'my-block'

// Define a block with modifier(s) using an object.
block({ modifier: true });
// 'my-block my-block--modifier'

block({ camelCase: true });
// 'my-block my-block--camel-case'

// Define a block with modifier(s) using an array.
block(['modifier'];
// 'my-block my-block--modifier'

// Define an element.
block('my-element');
// 'my-block__my-element'

// Define an element with modifiers using an object.
block('my-element', { modifier: true });
// 'my-block__my-element my-block__my-element--modifier'

// Define an element with modifiers using an array.
block('my-element', ['modifier'];
// 'my-block__my-element my-block__my-element--modifier'

API

purebem(block: string/number) -> ([ modifiers: array/object ]) -> string

purebem(block: string/number) -> ([ element: string/number [, modifiers: array/object ] ]) -> string

The purebem takes one argument and returns a function taking multiple arguments.

block

Type: string or number

The block name.

element

Type: string or number

The element name.

modifiers

Type: array or object.

The modifiers.

License

MIT

About

A BEM CSS methodology utility helper

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published