round()
Baseline 2024Newly available
Since May 2024, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
Die round()
CSS Funktion gibt eine gerundete Zahl basierend auf einer ausgewählten Rundungsstrategie zurück.
Autoren sollten eine benutzerdefinierte CSS-Eigenschaft (z. B. --my-property
) für den Rundungswert, das Intervall oder beides verwenden; die Nutzung der round()
Funktion ist überflüssig, wenn diese Werte bekannt sind.
Syntax
width: round(var(--width), 50px);
width: round(up, 101px, var(--interval));
width: round(down, var(--height), var(--interval));
margin: round(to-zero, -105px, 10px);
Parameter
Die Funktion round(<rounding-strategy>, valueToRound, roundingInterval)
gibt eine optionale Rundungsstrategie an, einen zu rundenden Wert (oder mathematischen Ausdruck) und ein Rundungsintervall (oder mathematischen Ausdruck).
Der valueToRound
wird gemäß der Rundungsstrategie zum nächsten ganzzahligen Vielfachen von roundingInterval
gerundet.
<rounding-strategy>
-
Die Rundungsstrategie. Dies kann einer der folgenden Werte sein:
up
-
Rundet
valueToRound
auf das nächsthöhere ganzzahlige Vielfache vonroundingInterval
(wenn der Wert negativ ist, wird er "positiver"). Dies entspricht der JavaScript-MethodeMath.ceil()
. down
-
Rundet
valueToRound
auf das nächstniedrigere ganzzahlige Vielfache vonroundingInterval
(wenn der Wert negativ ist, wird er "negativer"). Dies entspricht der JavaScript-MethodeMath.floor()
. nearest
(Standard)-
Rundet
valueToRound
auf das nächstgelegene ganzzahlige Vielfache vonroundingInterval
, das entweder über oder unter dem Wert liegen kann. WennvalueToRound
genau zwischen den Rundungszielen oberhalb und unterhalb liegt (keines ist "näher"), wird aufgerundet. Entspricht JavaScriptMath.round()
. to-zero
-
Rundet
valueToRound
auf das nächstgelegene ganzzahlige Vielfache vonroundingInterval
, das näher zu/null geht (eine positive Zahl verringert sich, während ein negativer Wert "weniger negativ" wird). Dies entspricht der JavaScript-MethodeMath.trunc()
.
valueToRound
-
Der zu rundende Wert. Dies muss ein
<number>
,<dimension>
, oder<percentage>
, oder ein mathematischer Ausdruck sein, der sich in einen dieser Werte auflöst. roundingInterval
-
Das Rundungsintervall. Dies ist ein
<number>
,<dimension>
, oder<percentage>
, oder ein mathematischer Ausdruck, der sich in einen dieser Werte auflöst.
Rückgabewert
Der Wert von valueToRound
, gerundet auf das nächste tiefere oder höhere ganzzahlige Vielfache von roundingInterval
, abhängig von der rounding strategy
.
-
Wenn
roundingInterval
0 ist, ist das ErgebnisNaN
. -
Wenn
valueToRound
undroundingInterval
beideunendlich
sind, ist das ErgebnisNaN
. -
Wenn
valueToRound
unendlich, aberroundingInterval
endlich ist, ist das Ergebnis das gleicheUnendlich
. -
Wenn
valueToRound
endlich, aberroundingInterval
unendlich ist, hängt das Ergebnis von der Rundungsstrategie und dem Vorzeichen vonA
ab:up
- WennvalueToRound
positiv (nicht null) ist, geben Sie+∞
zurück. WennvalueToRound
0⁺
ist, geben Sie0⁺
zurück. Andernfalls geben Sie0⁻
zurück.down
- WennvalueToRound
negativ (nicht null) ist, geben Sie−∞
zurück. WennvalueToRound
0⁻
ist, geben Sie0⁻
zurück. Andernfalls geben Sie0⁺
zurück.nearest
,to-zero
- WennvalueToRound
positiv oder0⁺
ist, geben Sie0⁺
zurück. Andernfalls geben Sie0⁻
zurück.
-
Die Argumentberechnungen können sich in
<number>
,<dimension>
, oder<percentage>
auflösen, müssen jedoch denselben Typ haben, andernfalls ist die Funktion ungültig; das Ergebnis wird denselben Typ wie die Argumente haben. -
Wenn
valueToRound
genau einem ganzzahligen Vielfachen vonroundingInterval
entspricht, löst sichround()
genau invalueToRound
auf (wobei beibehalten wird, obvalueToRound
0⁻
oder0⁺
ist, falls relevant). Andernfalls gibt es zwei ganzzahlige Vielfache vonroundingInterval
, die potenziell "am nächsten" zuvalueToRound
liegen, ein niedrigeresroundingInterval
, das näher zu−∞
ist, und ein höheresroundingInterval
, das näher zu+∞
ist.
Formale Syntax
<round()> =
round( <rounding-strategy>? , <calc-sum> , <calc-sum>? )
<rounding-strategy> =
nearest |
up |
down |
to-zero
<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
Beispiele
Positive Werte runden
Dieses Beispiel demonstriert, wie die round()
Funktion Rundungsstrategien für positive Werte anwendet.
Von den fünf Kästchen unten wird die round()
Funktion verwendet, um die Höhe der letzten vier festzulegen.
Der zu rundende Wert liegt jeweils zwischen 100 px und 125 px, und der Rundungswert ist in allen Fällen 25px.
Die Höhe der Kästchen wird daher entweder auf 125 px aufgerundet oder auf 100 px abgerundet.
HTML
Das HTML definiert 5 div
Elemente, die von der CSS als Kästchen gerendert werden.
Die Elemente enthalten Text, der die Rundungsstrategie, den Anfangswert und die erwartete endgültige Höhe des Kästchens (in Klammern) angibt.
<div class="box box-1">height: 100px</div>
<div class="box box-2">up 101px (125px)</div>
<div class="box box-3">down 122px (100px)</div>
<div class="box box-4">to-zero 120px (100px)</div>
<div class="box box-5">nearest 117px (125px)</div>
CSS
Der CSS, der auf alle Kästchen angewendet wird, ist unten gezeigt.
Beachten Sie, dass wir eine benutzerdefinierte CSS-Eigenschaft namens --rounding-interval
anwenden, die wir für das Rundungsintervall verwenden werden.
div.box {
width: 100px;
height: 100px;
background: lightblue;
--rounding-interval: 25px;
}
Das erste div
von links wird nicht mit spezifischen CSS-Regeln angesprochen, sodass es eine Standardhöhe von 100px haben wird.
Der CSS für div
zwei, drei und vier wird unten gezeigt, die nach oben, unten und zur Null runden.
div.box-2 {
height: round(up, 101px, var(--rounding-interval));
}
div.box-3 {
height: round(down, 122px, var(--rounding-interval));
}
div.box-4 {
height: round(to-zero, 120px, var(--rounding-interval));
}
Beachten Sie, wie wir oben das Rundungsintervall mit var()
und der benutzerdefinierten CSS-Eigenschaft --rounding-interval
angeben.
Das letzte Kästchen wird ohne eine Rundungsstrategie festgelegt und daher wird nearest
als Standard verwendet.
In diesem Fall ist das nächstgelegene Intervall zu 117 px 125px, daher wird es aufgerundet.
Nur zum Kontrast haben wir hier harte Werte für sowohl den Rundungswert als auch das Intervall angegeben.
Während dies erlaubt ist, würden Sie dies normalerweise nicht tun, da es keinen Sinn ergibt, eine Zahl zu runden, wenn Sie bereits wissen, was das Ergebnis sein muss.
div.box-5 {
height: round(117px, 25px);
}
Ergebnis
Wenn der Browser die CSS round()
Funktion unterstützt, sollten Sie fünf Spalten sehen mit Höhen, die entsprechend dem enthaltenen Text gerundet sind.
Spezifikationen
Specification |
---|
CSS Values and Units Module Level 4 # funcdef-round |
Browser-Kompatibilität
BCD tables only load in the browser