hypot()
Baseline 2023Newly available
Since December 2023, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
The hypot()
CSS function is an exponential function that returns the square root of the sum of squares of its parameters.
While pow()
and sqrt()
only work on unitless numbers, hypot()
accepts values with units, but they all must have the same type.
Syntax
/* A value */
width: hypot(2em); /* 2em */
width: hypot(3em, 4em); /* 5em */
width: hypot(30px, 40px); /* 50px */
width: hypot(48px, 64px); /* 80px */
width: hypot(3px, 4px, 5px); /* 7.0710678118654755px */
Parameters
The hypot(x [, ...]#)
function accepts one or more comma-separated calculations as its parameters.
Return value
Formal syntax
Examples
Sizes based on hypot function
This example shows how you can use the hypot()
function to calculate sizes.
HTML
100px
100px
141.42px
250px
CSS
Here we are using CSS custom properties to define the sizes to be used. First we declare the first size (--size-0
) which is then used to calculate the other sizes.
--size-1
is calculated with the hypotenuse of--size-0
(100px). This takes the square value and, as there is no other value, returns the square root of the value, which results in 100px.--size-2
is calculated with the hypotenuse of--size-0
(100px), twice. This takes the square of the value (100px * 100px = 10000px2) and adds it to the square of--size-0
again (10000px2 + 10000px2 = 20000px2) and returns the square root of the sum (√(20000px2)), which results in 141.42px.--size-3
is calculated with the hypotenuse--size-0
* 1.5 (150px) and--size-0
* 2 (200px). The result is the square root of the sum of their squares: The values are squared (22500px2 and 40000px2) and added together (62500px2), with the sum square-rooted (√(62500px2)) being 250px.
:root {
--size-0: 100px;
--size-1: hypot(var(--size-0)); /* 100px */
--size-2: hypot(var(--size-0), var(--size-0)); /* 141.42px */
--size-3: hypot(
calc(var(--size-0) * 1.5),
calc(var(--size-0) * 2)
); /* 250px */
}
The sizes are then applied as the width
and height
values of the selectors.
.one {
width: var(--size-1);
height: var(--size-1);
}
.two {
width: var(--size-2);
height: var(--size-2);
}
.three {
width: var(--size-3);
height: var(--size-3);
}
Result
Specifications
Specification |
---|
CSS Values and Units Module Level 4 # exponent-funcs |