Since June 2025, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
The sign() CSS function contains one calculation, and returns -1 if the numeric value of the argument is negative, +1 if the numeric value of the argument is positive, 0⁺ if the numeric value of the argument is 0⁺, and 0⁻ if the numeric value of the argument is 0⁻.
Note: While abs() returns the absolute value of the argument, sign() returns the sign of the argument.
/* property: sign( expression ) */ top: sign(20vh - 100px);
The sign(x) function accepts only one value as its parameter.
xA calculation which resolves to a number.
A number representing the sign of A:
x is positive, returns 1.x is negative, returns -1.x is positive zero, returns 0.x is negative zero, returns -0.NaN.<sign()> =
sign( <calc-sum> )
<calc-sum> =
<calc-product> [ [ '+' | '-' ] <calc-product> ]*
<calc-product> =
<calc-value> [ [ '*' | / ] <calc-value> ]*
<calc-value> =
<number> |
<dimension> |
<percentage> |
<calc-keyword> |
( <calc-sum> )
<calc-keyword> =
e |
pi |
infinity |
-infinity |
NaN
For example, in background-position positive percentages resolve to a negative length, and vice versa, if the background image is larger than the background area. Thus sign(10%) might return 1 or -1, depending on how the percentage is resolved! (Or even 0, if it's resolved against a zero length.)
div {
background-position: sign(10%);
}
Another use case is to control the position of the element. Either a positive or a negative value.
div {
position: absolute;
top: calc(100px * sign(var(--value)));
}
| Specification |
|---|
| CSS Values and Units Module Level 4> # sign-funcs> |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
sign |
138 | 138 | 118 | 122 | 15.4 | 138 | 118 | 91 | 15.4 | No | 138 | No |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/CSS/sign