Style Props Style props are a way to alter the style of a component by simply passing props
to it. It helps to save time by providing helpful shorthand ways to style
components.
The following table shows a list of every style prop and the properties within
each group.
import { Box } from "@chakra-ui/core"
< Box m = { 2 } > Tomato </ Box >
< Box maxW = " 960px " mx = " auto " />
< Box m = { [ 2 , 3 ] } />
Prop CSS Property Theme Key m
, margin
margin
space
mt
, marginTop
margin-top
space
mr
, marginRight
margin-right
space
mb
, marginBottom
margin-bottom
space
ml
, marginLeft
margin-left
space
mx
margin-left
and margin-right
space
my
margin-top
and margin-bottom
space
p
, padding
padding
space
pt
, paddingTop
padding-top
space
pr
, paddingRight
padding-right
space
pb
, paddingBottom
padding-bottom
space
pl
, paddingLeft
padding-left
space
px
padding-left
and padding-right
space
py
padding-top
and padding-bottom
space
Color and background color
# import { Box } from "@chakra-ui/core" ;
< Box color = ' gray.50 ' />
< Box color = ' #f00 ' />
< Box bg = ' tomato ' />
< Box backgroundColor = ' tomato ' />
Prop CSS Property Theme Key color
color
colors
bg
, background
background
colors
bgColor
background-color
colors
opacity
opacity
none
import { Text } from "@chakra-ui/core" ;
< Text fontSize = " md " />
< Text fontSize = { 32 } />
< Text fontSize = ' 2em ' />
< Text textAlign = { [ 'left' , 'center' ] } />
Prop CSS Property Theme Key fontFamily
font-family
fonts
fontSize
font-size
fontSizes
fontWeight
font-weight
fontWeights
lineHeight
line-height
lineHeights
letterSpacing
letter-spacing
letterSpacings
textAlign
text-align
none fontStyle
font-style
none textTransform
text-transform
none textDecoration
text-decoration
none
Layout, width and height
# import { Box } from "@chakra-ui/core" ;
< Box width = " 100% " height = { 32 } /> ;
< Box w = " 100% " h = " 32px " /> ;
< Box w = { 1 / 2 } />
< Box w = { 256 } />
< Box w = ' 40px ' />
Prop CSS Property Theme Key w
, width
width
sizes
h
, height
height
sizes
minW
, minWidth
min-width
sizes
maxW
, maxWidth
max-width
sizes
minH
, minHeight
min-height
sizes
maxH
, maxHeight
max-height
sizes
d
, display
display
none boxSize
width
, height
sizes
verticalAlign
vertical-align
none overflow
overflow
none overflowX
overflowX
none overflowY
overflowY
none
import { Box , Flex } from "@chakra-ui/core"
< Box display = " flex " alignItems = " center " justifyContent = " space-between " >
Box with Flex props
</ Box >
< Flex align = " center " justify = " center " >
Flex Container
</ Flex >
Note: Props in *
will only work if you use the Flex
component.
Prop CSS Property Theme Key alignItems
, *align
align-items
none alignContent
align-content
none justifyItems
justify-items
none justifyContent
, *justify
justify-content
none flexWrap
, *wrap
flex-wrap
none flexDirection
, flexDir
, *direction
flex-direction
none flex
flex
none flexGrow
flex-grow
none flexShrink
flex-shrink
none flexBasis
flex-basis
none justifySelf
justify-self
none alignSelf
align-self
none order
order
none
import { Box , Grid } from "@chakra-ui/core"
< Box display = " grid " gridGap = { 2 } gridAutoFlow = " row dense " >
Grid
</ Box >
< Grid gap = { 2 } autoFlow = " row dense " >
Grid
</ Grid >
Note: Props in *
will only work if you use the Grid
component.
Prop CSS Property Theme Key gridGap
, *gap
grid-gap
space
gridRowGap
, *rowGap
grid-row-gap
space
gridColumnGap
, *columnGap
grid-column-gap
space
gridColumn
, *column
grid-column
none gridRow
, *row
grid-row
none gridArea
, *area
grid-area
none gridAutoFlow
, *autoFlow
grid-auto-flow
none gridAutoRows
, *autoRows
grid-auto-rows
none gridAutoColumns
, *autoColumns
grid-auto-columns
none gridTemplateRows
, *templateRows
grid-template-rows
none gridTemplateColumns
, *templateColumns
grid-template-columns
none gridTemplateAreas
, *templateAreas
grid-template-areas
none
import { Box } from "@chakra-ui/core"
< Box
backgroundImage = " url('/images/kyuubi.png') "
backgroundPosition = " center "
backgroundRepeat = " no-repeat "
/>
< Box
bgImage = " url('/images/gaara.png') "
bgPosition = " center "
bgRepeat = " no-repeat "
/>
Prop CSS Property Theme Key background
background
none bgImage
, backgroundImage
background-image
none bgSize
, backgroundSize
background-size
none bgPosition
,backgroundPosition
background-position
none bgRepeat
,backgroundRepeat
background-repeat
none bgAttachment
,backgroundAttachment
background-attachment
none
< Box border = " 1px " borderColor = " gray.200 " >
Card
</ Box >
Prop CSS Property Theme Field border
border
borders
borderWidth
border-width
borderWidths
borderStyle
border-style
borderStyles
borderColor
border-color
colors
borderTop
border-top
borders
borderTopWidth
border-top-width
borderWidths
borderTopStyle
border-top-style
borderStyles
borderTopColor
border-top-color
colors
borderRight
border-right
borders
borderRightWidth
border-right-width
borderWidths
borderRightStyle
border-right-style
borderStyles
borderRightColor
border-right-color
colors
borderBottom
border-bottom
borders
borderBottomWidth
border-bottom-width
borderWidths
borderBottomStyle
border-bottom-style
borderStyles
borderBottomColor
border-bottom-color
colors
borderLeft
border-left
borders
borderLeftWidth
border-left-width
borderWidths
borderLeftStyle
border-left-style
borderStyles
borderLeftColor
border-left-color
colors
borderX
border-left
, border-right
borders
borderY
border-top
, border-bottom
borders
import { Button } from "@chakra-ui/core"
< Button borderRightRadius = " 0 " > Button 1 </ Button >
< Button borderLeftRadius = " 0 " > Button 2 </ Button >
< Button borderTopRadius = " md " > Button 2 </ Button >
Prop CSS Property Theme Field borderRadius
border-radius
radii
borderTopLeftRadius
border-top-left-radius
radii
borderTopRightRadius
border-top-right-radius
radii
borderBottomRightRadius
border-bottom-right-radius
radii
borderBottomLeftRadius
border-bottom-left-radius
radii
borderTopRadius
border-top-left-radius
& border-top-right-radius
radii
borderRightRadius
border-top-right-radius
& border-bottom-right-radius
radii
borderBottomRadius
border-bottom-left-radius
& border-bottom-right-radius
radii
borderLeftRadius
border-top-left-radius
& border-bottom-left-radius
radii
import { Box } from "@chakra-ui/core"
< Box position = " absolute " > Cover </ Box >
< Box pos = " absolute " > Cover </ Box >
< Box pos = " absolute " top = " 0 " left = " 0 " >
Absolute with top and left
</ Box >
< Box pos = " fixed " w = " 100% " zIndex = { 2 } >
Fixed with zIndex
</ Box >
Prop CSS Property Theme Field pos
,position
position
none zIndex
z-index
zIndices
top
top
space
right
right
space
bottom
bottom
space
left
left
space
import { Box , Text } from "@chakra-ui/core"
< Box textShadow = " sm " boxShadow = " md " />
< Text textShadow = " 2px 2px #ff0000 " boxShadow = " 5px 10px #888888 " >
Text with shadows
</ Text >
Prop CSS Property Theme Field textShadow
text-shadow
shadows
boxShadow
box-shadow
shadows
import { Button } from "@chakra-ui/core"
; < Button
colorScheme = " teal "
_hover = { {
background : "white" ,
color : "teal.500" ,
} }
>
Hover me
</ Button >
Prop CSS Property Theme Field _hover
:hover
,
[data-hover]
none _active
:active
,
[data-active]
none _focus
:focus
,
[data-focus]
none _highlighted
[data-highlighted]
none _focusWithin
:focus-within
none _focusVisible
:focus-visible
none _disabled
[disabled]
,
[aria-disabled=true]
,
[data-disabled]
none _readOnly
[aria-readonly=true]
,
[readonly]
,
[data-readonly]
none _before
::before
none _after
::after
none _empty
:empty
none _expanded
[aria-expanded=true]
,
[data-expanded]
none _checked
[aria-checked=true]
,
[data-checked]
none _grabbed
[aria-grabbed=true]
,
[data-grabbed]
none _pressed
[aria-pressed=true]
,
[data-pressed]
none _invalid
[aria-invalid=true]
,
[data-invalid]
none _valid
[data-valid]
,
[data-state=valid]
none _loading
[data-loading]
,
[aria-busy=true]
none _selected
[aria-selected=true]
,
[data-selected]
none _hidden
[hidden]
,
[data-hidden]
none _autofill
:-webkit-autofill
none _even
:nth-of-type(even)
none _odd
:nth-of-type(odd)
none _first
:first-of-type
none _last
:last-of-type
none _notFirst
:not(:first-of-type)
none _notLast
:not(:last-of-type)
none _visited
:visited
none _activeLink
[aria-current=page]
none _indeterminate
:indeterminate
,
[aria-checked=mixed]
,
[data-indeterminate]
none _groupHover
`` none _groupFocus
`` none _groupActive
`` none _groupDisabled
`` none _groupInvalid
`` none _groupChecked
`` none _placeholder
::placeholder
none _fullScreen
:fullscreen
none _selection
::selection
none
Asides all the common style props listed above, all component will accept the
following props:
Prop CSS Property Theme Field animation
animation
none appearance
appearance
none transform
transform
none transformOrigin
transform-origin
none visibility
visibility
none whiteSpace
white-space
none userSelect
user-select
none pointerEvents
pointer-events
none wordBreak
word-break
none overflowWrap
overflow-wrap
none textOverflow
text-overflow
none boxSizing
box-sizing
none cursor
cursor
none resize
resize
none transition
transition
none objectFit
object-fit
none objectPosition
object-position
none objectPosition
object-position
none float
float
none fill
fill
colors
stroke
stroke
colors
outline
outline
none
The as
prop is a feature that all of our components that allows you to pass an
HTML tag or component to be rendered.
For example, say you are using a Button
component, and you need to make it a
link instead. You can compose a
and Button
like this:
< Button as = " a " target = " _blank " variant = " outline " href = " https://chakra-ui.com " >
Hello
</ Button >
copy Editable Example
This allows you to use all of the Button
props and all of the a
props
without having to wrap the Button in an a
component.
Previous
Comparison
Next
Color Mode