JSS is designed to stay as close as possible to the CSS syntax, however there are some exceptions.
const styles = {
button: {
color: 'red',
'font-size': '12px'
}
}
Compiles to:
.button-jss-0 {
color: red;
font-size: 12px;
}
If you want dynamic behavior for your Style Sheet, you can use functions as a value which return the actual value. If function values returns null|undefined|false
- property will be removed. Use sheet.update(data) in order to pass the data object. Sheet option link: true
is required for this to function.
const styles = {
button: {
color: data => data.color
}
}
To use the !important
modifier with function values, you must use array syntax:
const styles = {
button: {
color: data => [[data.color], '!important']
}
}
Similar to function values, you can use a function to return a dynamic style object. Use sheet.update(data) in order to pass the data object. Sheet option link: true
is required for this to function.
const styles = {
button: data => ({
display: 'flex',
color: data.color
})
}
In order to create highly dynamic animations, you may want to use streams. Take a look at the tc39 observable proposal. Sheet option link: true
is required for this to function.
const styles = {
button: {
color: new Observable(observer => {
observer.next('red')
})
}
}
Similar to observable values, you can declare observable rules. Stream should contain in this case the style object. Sheet option link: true
is required for this to function.
const styles = {
button: new Observable(observer => {
observer.next({
color: 'red',
opacity: 1
})
})
}
const styles = {
button: {
width: 100
},
'@media (min-width: 1024px)': {
button: {
width: 200
}
}
}
const minWidth = 1024
const styles = {
button: {
width: 100
},
[`@media (min-width: ${minWidth}px)`]: {
button: {
width: 200
}
}
}
Compiles to:
.button-jss-0 {
width: 100px;
}
@media (min-width: 1024px) : {
.button-jss-0 {
width: 200px;
}
}
Note: keyframe id is still global and may conflict.
const styles = {
'@keyframes my-animation': {
from: {opacity: 0},
to: {opacity: 1}
}
}
const animationId = random()
const styles = {
[`@keyframes ${animationId}`]: {
from: {opacity: 0},
to {opacity: 1}
}
}
Compiles to:
@keyframes my-animation {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
const styles = {
container: {
background: 'linear-gradient(to right, red 0%, green 100%)'
fallbacks: {
background: 'red'
}
}
}
// Or if you need multiple fallbacks for the same property name:
const styles = {
container: {
display: 'flex'
fallbacks: [
{display: 'box'},
{display: 'flex-box'}
]
}
}
Compiles to:
.container--jss-0-0 {
background: red;
background: linear-gradient(to right, red 0%, green 100%);
}
const styles = {
'@font-face': {
fontFamily: 'MyWebFont',
src: 'url(webfont.eot)'
}
}
Compiles to:
@font-face {
font-family: 'MyWebFont';
src: url('webfont.eot');
}
// Multiple font faces.
const styles = {
'@font-face': [
{
fontFamily: 'MyWebFont',
src: 'url(webfont.eot)'
},
{
fontFamily: 'MySecondFont',
src: 'url(webfont2.eot)'
}
]
}
Compiles to:
@font-face {
font-family: 'MyWebFont';
src: url('webfont.eot');
}
@font-face {
font-family: 'MySecondFont';
src: url('webfont2.eot');
}
// Font-Face with src fallbacks.
const styles = {
'@font-face': {
fontFamily: 'MyWebFont',
src: 'url(webfont.eot)',
fallbacks: [
{src: 'url(webfont.eot?#iefix) format(embedded-opentype)'},
{src: 'url(webfont.woff2) format(woff2)'}
]
}
}
Compiles to:
@font-face {
font-family: 'MyWebFont';
src: url('webfont.eot');
src: url(webfont.eot?#iefix) format(embedded-opentype);
src: url(webfont.woff2) format(woff2);
}
In order to describe space or comma separated CSS values in a JavaScript way, we introduced an array based syntax.
There are some advantages in using this syntax:
- Plugin
jss-default-unit
is able to set default unit effectively for numeric values. - You can use variables inside of a value declaration without string templates or concatenations.
const styles = {
button: {
// Comma separated value with regular CSS strings inside.
border: ['1px solid red', '1px solid blue']
}
}
Compiles to:
.button-12345 {
border: 1px solid red, 1px solid blue;
}
const styles = {
button: {
// Comma separated value with space separated values inside.
border: [
// Numbers can become default unit automatically.
[1, 'solid', 'red'],
[1, 'solid', 'blue']
]
}
}
Compiles to:
.button-12345 {
border: 1px solid red, 1px solid blue;
}
const styles = {
button: {
// Space separated value.
margin: [[5, 10]]
}
}
Compiles to:
.button-12345 {
margin: 5px 10px;
}
const styles = {
button: {
color: [['red'], '!important'],
margin: [[5, 10], '!important']
}
}
Compiles to:
.button-12345 {
color: red !important;
margin: 5px 10px !important;
}
Global selectors can be used when the jss-global plugin is installed.
Are supported through the jss-nested plugin.
When assigning a string to the content property it requires double or single quotes in CSS. Therefore you also have to provide the quotes within the value string for content to match how it will be represented in CSS.
const styles = {
button: {
'&:after': {
content: '"JSS"'
}
}
}
Compiles to:
.button-jss-0-1:after {
content: 'JSS';
}
You can use any color conversion tool, for e.g. this one.
import color from 'color'
const styles = {
button: {
color: color('blue')
.darken(0.3)
.hex()
}
}
Compiles to:
.button-jss-0-1 {
color: '#0000B3';
}
JSS plugins give you even more features, read about them.