oklch()
Baseline 2023
Newly available
Since May 2023, this feature works across the latest devices and browser versions. This feature might not work in older devices or browsers.
Die oklch()
funktionale Notation drückt eine gegebene Farbe im Oklab-Farbraum aus. oklch()
ist die zylindrische Form von oklab()
, die dieselbe L
-Achse verwendet, aber mit polaren Chroma- (C
) und Farbton- (h
) Koordinaten.
Syntax
/* Absolute values */
oklch(40.1% 0.123 21.57)
oklch(59.69% 0.156 49.77)
oklch(59.69% 0.156 49.77 / .5)
/* Relative values */
oklch(from green l c h / 0.5)
oklch(from #0000FF calc(l + 0.1) c h)
oklch(from hsl(180 100% 50%) calc(l - 0.1) c h)
oklch(from var(--aColor) l c h / calc(alpha - 0.1))
Werte
Nachfolgend finden Sie Beschreibungen der zulässigen Werte für absolute und relative Farben.
Hinweis: Normalerweise, wenn Prozentwerte in CSS eine numerische Entsprechung haben, ist 100%
gleich der Zahl 1
.
Dies gilt nicht für alle oklch()
-Komponentenwerte. Hier ist 100%
gleich 0.4
für den C
-Wert.
Absolute Wert-Syntax
oklch(L C H[ / A])
Die Parameter sind wie folgt:
L
-
Eine
<number>
zwischen0
und1
, ein<percentage>
zwischen0%
und100%
, oder das Schlüsselwortnone
(entspricht0%
in diesem Fall). In diesem Fall entspricht die Zahl0
0%
(schwarz) und die Zahl1
entspricht100%
(weiß). Dieser Wert spezifiziert die wahrgenommene Helligkeit der Farbe, oder "Leuchtkraft".Hinweis: Das
L
inoklch()
ist die wahrgenommene Helligkeit, die sich auf die "Leuchtkraft" bezieht, die wir visuell mit unseren Augen wahrnehmen. Dies ist anders als dasL
inhsl()
, wo es die Helligkeit im Vergleich zu anderen Farben darstellt. C
-
Eine
<number>
, ein<percentage>
, oder das Schlüsselwortnone
(entspricht0%
in diesem Fall). Dieser Wert ist ein Maß für das Chroma der Farbe (ungefähr die "Menge der Farbe" repräsentierend). Sein minimaler nützlicher Wert ist0
, während der maximale theoretisch unbegrenzt ist (in der Praxis jedoch0.5
nicht übersteigt). In diesem Fall ist0%
0
und100%
ist die Zahl0.4
. H
-
Eine
<number>
, ein<angle>
, oder das Schlüsselwortnone
(entspricht0deg
in diesem Fall), das den Farbwinkel der<hue>
darstellt.Hinweis: Die Winkel, die bestimmten Farbtönen entsprechen, unterscheiden sich zwischen den sRGB (verwendet von
hsl()
undhwb()
), CIELAB (verwendet vonlch()
) und Oklab (verwendet vonoklch()
) Farbräumen. Siehe das Beispiel Farbtöne inoklch()
unten und die<hue>
Referenzseite für weitere Details und Beispiele. A
Optional-
Ein
<alpha-value>
, das den Alphakanal der Farbe repräsentiert, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig deckend) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit anzugeben, dass kein Alphakanal vorhanden ist. Wenn derA
-Kanalwert nicht explizit festgelegt ist, wird standardmäßig 100 % verwendet. Wenn er enthalten ist, wird der Wert durch einen Schrägstrich (/
) vorangestellt.
Hinweis: Weitere Informationen zur Wirkung von none
finden Sie unter Fehlende Farbkomponenten.
Relative Wert-Syntax
oklch(from <color> L C H[ / A])
Die Parameter sind wie folgt:
from <color>
-
Das Schlüsselwort
from
wird immer eingeschlossen, wenn eine relative Farbe definiert wird, gefolgt von einem<color>
Wert, der die Ursprungsfarbe darstellt: Dies ist die ursprüngliche Farbe, auf der die relative Farbe basiert. Die Ursprungsfarbe kann jede gültige<color>
Syntax sein, einschließlich einer anderen relativen Farbe. L
-
Eine
<number>
zwischen0
und1
, ein<percentage>
zwischen0%
und100%
, oder das Schlüsselwortnone
(entspricht0%
in diesem Fall). Dies repräsentiert den Helligkeitswert der Ausgabefarbe. Hier entspricht die Zahl0
0%
(schwarz) und die Zahl1
entspricht100%
(weiß). C
-
Eine
<number>
, ein<percentage>
, oder das Schlüsselwortnone
(entspricht0%
in diesem Fall). Dieser Wert repräsentiert den Chroma-Wert der Ausgabefarbe (ungefähr die "Menge der Farbe" repräsentierend). Sein minimaler nützlicher Wert ist0
, während der maximale theoretisch unbegrenzt ist (in der Praxis jedoch0.5
nicht übersteigt). In diesem Fall ist0%
0
und100%
ist die Zahl0.4
. H
-
Eine
<number>
, ein<angle>
, oder das Schlüsselwortnone
(entspricht0deg
in diesem Fall), das den Farbwinkel der Ausgabefarbe<hue>
repräsentiert. Siehe ein Beispiel für verschiedene Farbtöne im Abschnitt Beispiele unten. A
Optional-
Ein
<alpha-value>
, das den Alphakanal-Wert der Ausgabefarbe repräsentiert, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig deckend) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit anzugeben, dass kein Alphakanal vorhanden ist. Wenn derA
-Kanalwert nicht explizit angegeben ist, wird standardmäßig der Alphakanalwert der Ursprungsfarbe verwendet. Wenn er enthalten ist, wird der Wert durch einen Schrägstrich (/
) vorangestellt.
Definition relativer Farb-Ausgabekanalkomponenten
Wenn Sie die relative Farbsyntax innerhalb einer oklch()
-Funktion verwenden, konvertiert der Browser die Ursprungsfarbe in eine äquivalente Oklch-Farbe (wenn sie nicht bereits so spezifiziert ist). Die Farbe wird als drei verschiedene Farbkanalwerte definiert — l
(Helligkeit), c
(Chroma) und h
(Farbton) — sowie ein Alphakanalwert (alpha
). Diese Kanalwerte stehen innerhalb der Funktion zur Verfügung, um bei der Definition der Ausgabefarbkanalwerte verwendet zu werden:
- Der
l
-Kanalwert wird auf einen<number>
zwischen0
und1
, inklusive, aufgelöst. - Der
c
-Kanalwert wird auf einen<number>
zwischen0
und0.4
, inklusive, aufgelöst. - Der
h
-Kanalwert wird auf einen<number>
zwischen0
und360
, inklusive, aufgelöst. - Der
alpha
-Kanal wird auf einen<number>
zwischen0
und1
, inklusive, aufgelöst.
Bei der Definition einer relativen Farbe können die verschiedenen Kanäle der Ausgabefarbe auf verschiedene Weise ausgedrückt werden. Im Folgenden werden einige Beispiele studiert, um diese zu veranschaulichen.
In den ersten beiden Beispielen unten verwenden wir die relative Farbsyntax. Das erste gibt jedoch dieselbe Farbe wie die Ursprungsfarbe aus und das zweite gibt eine Farbe aus, die überhaupt nicht auf der Ursprungsfarbe basiert. Sie erstellen eigentlich keine relativen Farben! Sie würden diese wahrscheinlich nie in einer realen Codebasis verwenden und wahrscheinlich eher einen absoluten Farbwert nehmen. Wir haben diese Beispiele als Ausgangspunkt zum Lernen der relativen oklch()
-Syntax aufgenommen.
Beginnen wir mit einer Ursprungsfarbe von hsl(0 100% 50%)
(entspricht rot
). Die folgende Funktion gibt dieselbe Farbe wie die Ursprungsfarbe aus — sie verwendet die l
-, c
- und h
-Kanalwerte der Ursprungsfarbe (0.627966
, 0.257704
und 29.2346
) als Ausgabekanalwerte:
oklch(from hsl(0 100% 50%) l c h)
Die Ausgabe dieser Funktion ist die Farbe oklch(0.627966 0.257704 29.2346)
.
Die nächste Funktion verwendet absolute Werte für die Ausgabefarbkanalwerte und gibt eine völlig andere Farbe aus, die nicht auf der Ursprungsfarbe basiert:
oklch(from hsl(0 100% 50%) 42.1% 0.25 328.363)
In diesem Fall ist die Ausgabefarbe oklch(0.421 0.25 328.363)
.
Die folgende Funktion erstellt eine relative Farbe basierend auf der Ursprungsfarbe:
oklch(from hsl(0 100% 50%) 0.8 0.4 h)
Dieses Beispiel:
- Konvertiert die
hsl()
-Ursprungsfarbe in eine äquivalenteoklch()
-Farbe —oklch(0.627966 0.257704 29.2346)
. - Setzt den
H
-Kanalwert der Ausgabefarbe auf denH
-Kanalwert der äquivalentenoklch()
-Ursprungsfarbe —29.2346
. - Setzt die
L
- undC
-Kanalwerte der Ausgabefarbe auf neue Werte, die nicht auf der Ursprungsfarbe basieren:0.8
und0.4
respektive.
Die endgültige Ausgabefarbe ist oklch(0.8 0.4 29.2346)
.
Hinweis: Wie oben erwähnt, wenn die Ausgabefarbe ein anderes Farbmodell als die Ursprungsfarbe verwendet, wird die Ursprungsfarbe im Hintergrund in dasselbe Modell wie die Ausgabefarbe umgewandelt, um sie in einer Weise zu repräsentieren, die kompatibel ist (d. h. dieselben Kanäle verwendet).
In den Beispielen, die wir bisher in diesem Abschnitt gesehen haben, wurden die Alphakanäle weder für die Ursprungs- noch für die Ausgabefarben explizit festgelegt. Wenn der Ausgabefarben-Alphakanal nicht angegeben ist, wird standardmäßig derselbe Wert wie der Ursprungsfarben-Alphakanal verwendet. Wenn der Ursprungsfarben-Alphakanal nicht angegeben ist (und es sich nicht um eine relative Farbe handelt), wird standardmäßig 1
verwendet. Daher sind die Ursprungs- und Ausgabewert der Alphakanäle in den obigen Beispielen 1
.
Lassen Sie uns einige Beispiele betrachten, die Ursprungs- und Ausgabefarb-Alphakanalwerte spezifizieren. Das erste Beispiel spezifiziert den Ausgabefarb-Alphakanalwert als denselben wie den Ursprungs-Alphakanalwert, während das zweite einen anderen Ausgabefarb-Alphakanalwert angibt, der nicht im Zusammenhang mit dem Ursprungs-Alphakanalwert steht.
oklch(from hsl(0 100% 50% / 0.8) l c h / alpha)
/* Computed output color: oklch(0.627966 0.257704 29.2346 / 0.8) */
oklch(from hsl(0 100% 50% / 0.8) l c h / 0.5)
/* Computed output color: oklch(0.627966 0.257704 29.2346 / 0.5) */
Im folgenden Beispiel wird die hsl()
-Ursprungsfarbe erneut in die oklch()
-Äquivalenz konvertiert — oklch(0.627966 0.257704 29.2346)
. calc()
-Berechnungen werden auf die L
-, C
-, H
- und A
-Werte angewendet, was zu einer Ausgabefarbe von oklch(0.827966 0.357704 9.23462 / 0.9)
führt:
oklch(from hsl(0 100% 50%) calc(l + 0.2) calc(c + 0.1) calc(h - 20) / calc(alpha - 0.1))
Hinweis: Da die Ursprungsfarbkanalwerte auf <number>
-Werte aufgelöst werden, müssen Sie Zahlen zu ihnen addieren, wenn Sie sie in Berechnungen verwenden, auch in Fällen, in denen ein Kanal normalerweise <percentage>
, <angle>
oder andere Wertetypen akzeptieren würde. Das Hinzufügen eines <percentage>
zu einem <number>
, zum Beispiel, funktioniert nicht.
Formale Syntax
Beispiele
Anpassen der Helligkeit einer Farbe
Dieses Beispiel zeigt die Wirkung der Variation des L
(Helligkeit)-Wertes der oklch()
-funktionalen Notation.
HTML
<div data-color="blue-dark"></div>
<div data-color="blue"></div>
<div data-color="blue-light"></div>
<div data-color="red-dark"></div>
<div data-color="red"></div>
<div data-color="red-light"></div>
<div data-color="green-dark"></div>
<div data-color="green"></div>
<div data-color="green-light"></div>
CSS
[data-color="blue-dark"] {
background-color: oklch(10% 0.4 240);
}
[data-color="blue"] {
background-color: oklch(50% 0.4 240);
}
[data-color="blue-light"] {
background-color: oklch(90% 0.4 240);
}
[data-color="red-dark"] {
background-color: oklch(10% 0.4 20);
}
[data-color="red"] {
background-color: oklch(50% 0.4 20);
}
[data-color="red-light"] {
background-color: oklch(90% 0.4 20);
}
[data-color="green-dark"] {
background-color: oklch(10% 0.4 130);
}
[data-color="green"] {
background-color: oklch(50% 0.4 130);
}
[data-color="green-light"] {
background-color: oklch(90% 0.4 130);
}
Ergebnis
Anpassung der Farbstärke über Chroma
Das folgende Beispiel zeigt die Wirkung der Variation des C
(Chroma)-Wertes der oklch()
-funktionalen Notation, wobei die Farben an Intensität abnehmen, wenn der C
-Wert von vollständig gesättigt zu fast grau abnimmt.
HTML
<div data-color="blue"></div>
<div data-color="blue-chroma1"></div>
<div data-color="blue-chroma2"></div>
<div data-color="blue-chroma3"></div>
<div data-color="red"></div>
<div data-color="red-chroma1"></div>
<div data-color="red-chroma2"></div>
<div data-color="red-chroma3"></div>
<div data-color="green"></div>
<div data-color="green-chroma1"></div>
<div data-color="green-chroma2"></div>
<div data-color="green-chroma3"></div>
CSS
Mit den anfänglichen Ausgangsfarben Blau, Rot und Grün deklarieren wir schrittweise kleinere Werte für Chroma auf ihnen: beginnend mit voller Farbsättigung am hohen Wert von 0.4
(entspricht 100%
) bis hin zu 0.01
(entspricht 2%
), was bei allen Farben fast grau ist.
[data-color="blue"] {
background-color: oklch(50% 0.4 240);
}
[data-color="blue-chroma1"] {
background-color: oklch(50% 0.2 240);
}
[data-color="blue-chroma2"] {
background-color: oklch(50% 0.1 240);
}
[data-color="blue-chroma3"] {
background-color: oklch(50% 0.01 240);
}
[data-color="red"] {
background-color: oklch(50% 100% 20deg);
}
[data-color="red-chroma1"] {
background-color: oklch(50% 50% 20deg);
}
[data-color="red-chroma2"] {
background-color: oklch(50% 25% 20deg);
}
[data-color="red-chroma3"] {
background-color: oklch(50% 2% 20deg);
}
[data-color="green"] {
background-color: oklch(50% 0.4 130);
}
[data-color="green-chroma1"] {
background-color: oklch(50% 0.2 130);
}
[data-color="green-chroma2"] {
background-color: oklch(50% 0.1 130);
}
[data-color="green-chroma3"] {
background-color: oklch(50% 0.01 130);
}
Ergebnis
Hätten wir 0
anstelle von 0.01
und 2%
mit den gleichen Helligkeitswerten verwendet, wären die Farben alle derselbe Grauton. In diesem Beispiel sind sie fast grau.
Farbtöne in oklch
Das folgende Beispiel zeigt Farbfelder mit verschiedenen H
(Farbton)-Werten der oklch()
-funktionalen Notation.
HTML
<div data-color="0">0deg</div>
<div data-color="20">20deg</div>
<div data-color="40">40deg</div>
<div data-color="60">60deg</div>
und so weiter.
CSS
[data-color="0"] {
background-color: oklch(50% 0.4 0deg);
}
[data-color="20"] {
background-color: oklch(50% 0.4 20deg);
}
[data-color="40"] {
background-color: oklch(50% 0.4 40deg);
}
[data-color="60"] {
background-color: oklch(50% 0.4 60deg);
}
und so weiter.
Ergebnis
Die Farbtonwinkel in oklch()
unterscheiden sich von denen in hsl()
. Siehe <hue>
für mehr Informationen. In hsl()
repräsentiert die sRGB-Farbe 0deg
Rot. Im CIELab-Farbraum entspricht 0deg
jedoch Magenta, während Rot ungefähr 41deg
ist.
Anpassen des Alphawerts einer Farbe
Das folgende Beispiel zeigt die Wirkung der Variation des A
(Alpha)-Wertes der oklch()
-Farb-Funktion. Die rot
- und rot-alpha
-Elemente überlappen das #background-div
-Element, um die Wirkung der Opazität zu demonstrieren. Wenn A
einen Wert von 0.4
erhält, wird die Farbe zu 40% deckend.
HTML
<div id="background-div">
<div data-color="red"></div>
<div data-color="red-alpha"></div>
</div>
CSS
[data-color="red"] {
background-color: oklch(50% 0.5 20);
}
[data-color="red-alpha"] {
background-color: oklch(50% 0.5 20 / 0.4);
}
Ergebnis
Verwendung relativer Farben mit oklch()
Dieses Beispiel gestaltet drei <div>
-Elemente mit unterschiedlichen Hintergrundfarben. Das mittlere erhält die unveränderte --base-color
, während die linken und rechten durch Aufhellen und Abdunkeln dieser --base-color
Variationen erhalten.
Diese Variationen werden durch relative Farben definiert — die benutzerdefinierte Eigenschaft --base-color
wird in eine oklch()
-Funktion eingespeist, und die Ausgabefarben haben ihren Helligkeitskanal so modifiziert, dass der gewünschte Effekt über eine calc()
-Funktion erreicht wird. Die aufgehellte Farbe hat 0.15
(15%) zum Helligkeitskanal hinzugefügt und die abgedunkelte Farbe hat 0.15
(15%) vom Helligkeitskanal subtrahiert.
CSS
:root {
--base-color: orange;
}
#one {
background-color: oklch(from var(--base-color) calc(l + 0.15) c h);
}
#two {
background-color: var(--base-color);
}
#three {
background-color: oklch(from var(--base-color) calc(l - 0.15) c h);
}
Ergebnis
Die Ausgabe ist wie folgt:
Spezifikationen
Specification |
---|
CSS Color Module Level 5 # relative-Oklch |
CSS Color Module Level 4 # ok-lab |
Browser-Kompatibilität
BCD tables only load in the browser
Siehe auch
- Liste aller Farbnotationen
- Verwendung relativer Farben
- CSS Farben Modul
<hue>
Datentyplch()
undoklab()
Farb-Funktionen- Interaktiver Beitrag über OKLCH-Farbraum (2024)
- OKLCH in CSS: Warum wir von RGB und HSL gewechselt sind (2024)
- Ein wahrnehmbarer Farbraum für die Bildverarbeitung (2020)