CSS Functions
Runtime contextual expressions that return dynamic real-time value per the state of the browser in that moment
- within global space, no need to import
- can be nested, calc(var(--v))
- typed, wrong type may fail, eg:
rotate(45px)
will not work - type cast, eg:
calc(5 * 60 * 60s)
- keep the function live, recompute on value changes and updates
- many of them are pure functions, counter-example:
counter()
1️⃣Color functions
rgb()
,rgba()
,hsl()
,hsla()
,lab()
,lch()
color()
.element {
color: rgb(255, 0, 0);
color: rgba(255, 0, 0, 1);
color: hsl(0deg, 100%, 50%);
color: hsla(0deg, 100%, 50%, 100%);
color: lab(53.23% 80.11 67.22);
color: lch(53.23% 104.58 40);
}
2️⃣Gradient functions
linear-gradient()
,repeating-linear-gradient()
top -> bottomradiant-gradient()
,repeating-radiant-gradient()
center -> outerconic-gradient()
andrepeating-conical-gradient()
clockwise
.element {
background: linear-gradient(45deg, lightcoral, beige);
background: repeating-linear-gradient(45deg, lightcoral 25px, beige 50px);
background: radial-gradient(lightcoral 25px, beige 50px);
background: repeating-radial-gradient(lightcoral 25px, beige 50px);
background: conic-gradient(lightcoral 25deg, beige 50deg);
background: repeating-conic-gradient(lightcoral 25deg, beige 50deg);
}
3️⃣ attr()
- allow you to read value from attribute of the element you are targeting
<div class="element" data-color="red" data-title="hello"></div>
<style>
.element::before {
content: attr(data-title);
/* Providing type-or-unit and fallback to `attr()` is still experimental */
color: attr(data-color color, blue);
}
</style>
4️⃣ var()
- allow you to insert value of the CSS Custom Property
:root {
--item-height: 42px;
}
.element {
height: var(--item-height);
/* with fallback value */
width: var(--item-width, 50px);
}
5️⃣ url()
- use for fetching assets
.element {
/* absolute url */
background-image: url(https://example.com/image.jpg);
/* relative url */
background-image: url(image.jpg);
/* base 64 data uri */
background-image: url(…);
/* reference to ID of an SVG shape */
offset-path: url(#mask);
}
6️⃣ image-set()
- grab image based on resolution
.element {
background-image: image-set(
'cat.png' 1x,
'cat-2x.png' 2x,
'cat-print.png' 600dpi
);
}
7️⃣ Functional Selectors
:is()
,:where()
:not()
,:lang()
,:dir()
,nth-child()
,nth-last-child()
,nth-of-type()
,nth-last-of-type()
- see pseudo selectors
8️⃣ Mathematical Functions
calc()
,min()
,max()
,clamp()
.element {
height: calc(100vh - 42px);
/* set to smallest value between 8vw and 200px */
width: min(8vw, 200px);
/* set to biggest value between 8vw and 16px */
margin-top: max(8vw, 16px);
/* set to 2.5vw, but wont go smaller than 1rem and not larget than 2rem */
/* clamp(MIN, VAL, MAX) === max(MIN, min(VAL, MAX)) */
font-size: clamp(1rem, 2.5vw, 2rem);
}
9️⃣ Trigonometry Functions
sin()
,cos()
,acos()
,asin()
,atan()
,atan2()
,sqrt()
,hypot()
,pow()
1️⃣0️⃣ cubic-bezier()
.element {
animation: swing 1s cubic-bezier(0.6, 0, 1, 1);
}
1️⃣1️⃣ steps()
- divide the output value into equal distance steps.
- useful for animating sprites
.element {
animation: drive 10s steps(5, end);
}
1️⃣2️⃣ Shape Functions
path()
,circle()
,ellipse()
,polygon()
,inset()
.element {
offset-path: path('m5 0 l 300 300 l 0 300 l 5 0');
clip-path: ellipse(5px 8px);
shape-outside: circle(10px);
offset-path: inset(4px 16px);
clip-path: polygon(5px 0px, 300px 300px, 0 300px);
}
1️⃣3️⃣ Transform Functions
- scaleX(), scaleY(), scaleZ(), scale(), scale3d()
- perspective()
- translateX(), translateY(), translateZ(), translate(), translate3d()
- rotateX(), rotateY(), rotateZ(), rotate(), rotate3d()
- skewX(), skewY(), skew()
1️⃣4️⃣ Filter Functions
- blur(), brightness(), contrast(), grayscale(), hue-rotate(), invert(), opacity(), saturate(), sepia(), drop-shadow(), url()
.element {
filter: blur(1px);
filter: brightness(1.3);
filter: contrast(0.5);
filter: grayscale(0.4);
filter: sepia(1);
filter: invert(1);
filter: hue-rotate(45deg);
filter: opacity(0.5);
filter: drop-shadow(2px 4px 6px black);
}
1️⃣5️⃣ Grid Template Functions
fit-content()
,min-max()
,repeat()
1️⃣6️⃣ Media Queries
- @media
- @support
@media (min-width: 600px) {
.element {
background: blue;
}
}
/* Display-P3 color, when supported. */
@supports (color: color(display-p3 1 1 1)) {
.element {
color: color(display-p3 0 1 0);
}
}
1️⃣7️⃣ Vulnerabilities
- Billion Laughs Attack (https://drafts.csswg.org/css-variables/#long-variables)
- XSS through
url()
+attr()
- Third party CSS is not safe
/* Billion Laughs Attack */
/* create a value in custom property so big that it runs out of memory */
:root {
--v1: "lol";
--v2: var(--v1) var(--v1) var(--v1) var(--v1) var(--v1) var(--v1) var(--v1) var(--v1) var(--v1) var(--v1);
--v3: var(--v2) var(--v2) var(--v2) var(--v2) var(--v2) var(--v2) var(--v2) var(--v2) var(--v2) var(--v2);
--v4: var(--v3) var(--v3) var(--v3) var(--v3) var(--v3) var(--v3) var(--v3) var(--v3) var(--v3) var(--v3);
--v5: var(--v4) var(--v4) var(--v4) var(--v4) var(--v4) var(--v4) var(--v4) var(--v4) var(--v4) var(--v4);
--v6: var(--v5) var(--v5) var(--v5) var(--v5) var(--v5) var(--v5) var(--v5) var(--v5) var(--v5) var(--v5);
--v7: var(--v6) var(--v6) var(--v6) var(--v6) var(--v6) var(--v6) var(--v6) var(--v6) var(--v6) var(--v6);
--v8: var(--v7) var(--v7) var(--v7) var(--v7) var(--v7) var(--v7) var(--v7) var(--v7) var(--v7) var(--v7);
--v9: var(--v8) var(--v8) var(--v8) var(--v8) var(--v8) var(--v8) var(--v8) var(--v8) var(--v8) var(--v8);
--v10: var(--v9) var(--v9) var(--v9) var(--v9) var(--v9) var(--v9) var(--v9) var(--v9) var(--v9) var(--v9);
}