Skip to content

Latest commit

 

History

History
48 lines (35 loc) · 1.03 KB

styled.md

File metadata and controls

48 lines (35 loc) · 1.03 KB

styled()() Component Interface

styled component syntax allows you to "attach" styles to some HTML element. It is a HOC that receives a CSS-like object and returns a component that that will be styled accordingly.

Usage

Import styled() function.

import styled from 'freestyler/lib/styled';

Now create a styled <Border> component.

const Border = styled.div({
  border: '1px solid tomato',
  bdrad: '3px'
});

<Border>Hello world!</Border>

"Styled" component's styles can be a function that returns a CSS-like object. This function receives components props as an argument.

const Border = styled.div(({color = 'tomato'}) => ({
  border: '1px solid ' + color,
  bdrad: '3px'
}));

You can use style various predefined DOM elements.

styled.div(/* ... */);
styled.span(/* ... */);
styled.a(/* ... */);
styled.button(/* ... */);
// etc...

Or use your custom DOM elements.

const MyArticle = styled('article')(/* ... */);