oklch()
Baseline 2023Newly 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()
Funktionsnotation drückt eine bestimmte Farbe im Oklab-Farbraum aus. oklch()
ist die zylindrische Form von oklab()
, die die gleiche L
-Achse verwendet, jedoch mit Polar-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 #123456 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 die Beschreibungen der erlaubten Werte für absolute und relative Farben.
Hinweis:
In der Regel entspricht bei CSS, wenn Prozentwerte einen numerischen Äquivalent haben, 100%
der Zahl 1
.
Dies ist nicht für alle oklch()
-Komponentenwerte der Fall. Hier entspricht 100%
dem Wert 0.4
für den C
-Wert.
Absolute Wertsyntax
oklch(L C H[ / A])
Die Parameter sind wie folgt:
L
-
Eine
<number>
zwischen0
und1
, eine<percentage>
zwischen0%
und100%
oder das Schlüsselwortnone
(in diesem Fall äquivalent zu0%
). In diesem Fall entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). Dieser Wert gibt die wahrgenommene Helligkeit der Farbe an, oder "Leuchtkraft".Hinweis: Das
L
inoklch()
ist die wahrgenommene Helligkeit, die sich auf die "Leuchtkraft" bezieht, die wir mit unseren Augen visuell wahrnehmen. Dies unterscheidet sich vomL
inhsl()
, wo es die Helligkeit im Vergleich zu anderen Farben darstellt. C
-
Ein
<number>
, ein<percentage>
oder das Schlüsselwortnone
(in diesem Fall äquivalent zu0%
). Dieser Wert ist ein Maß für das Chroma der Farbe (ungefähr die "Menge an Farbe"). Sein minimaler nützlicher Wert ist0
, während das Maximum theoretisch unbegrenzt ist (aber in der Praxis nicht über0.5
hinausgeht). In diesem Fall ist0%
0
und100%
ist die Zahl0.4
. H
-
Ein
<number>
, ein<angle>
oder das Schlüsselwortnone
(in diesem Fall äquivalent zu0deg
), das den<hue>
-Winkel der Farbe 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>
Wert, der den Alphakanalwert der Farbe darstellt, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig deckend) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit keinen Alphakanal anzugeben. Wenn derA
-Kanalwert nicht explizit angegeben ist, beträgt der Standardwert 100%. Wenn er enthalten ist, wird der Wert durch einen Schrägstrich (/
) vorangestellt.
Hinweis:
Informationen über die Auswirkungen von none
finden Sie unter Fehlende Farbkomponenten.
Relative Wertsyntax
oklch(from <color> L C H[ / A])
Die Parameter sind wie folgt:
from <color>
-
Das immer enthaltene Schlüsselwort
from
beim Definieren einer relativen Farbe, gefolgt von einem<color>
Wert, der die Ursprungsfarbe darstellt: Dies ist die ursprüngliche Farbe, die die relative Farbe zugrunde liegt. Die Ursprungsfarbe kann jede gültige<color>
-Syntax sein, einschließlich einer anderen relativen Farbe. L
-
Eine
<number>
zwischen0
und1
, eine<percentage>
zwischen0%
und100%
oder das Schlüsselwortnone
(in diesem Fall gleichwertig zu0%
). Dies stellt den Helligkeitswert der Ausgabefarbe dar. Hier entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). C
-
Ein
<number>
, ein<percentage>
oder das Schlüsselwortnone
(in diesem Fall äquivalent zu0%
). Dieser Wert stellt den Chroma-Wert der Ausgabefarbe dar (ungefähr die "Menge an Farbe"). Sein minimaler nützlicher Wert ist0
, während sein Maximum theoretisch unbegrenzt ist (in der Praxis jedoch0.5
nicht überschreitet). In diesem Fall ist0%
0
und100%
ist die Zahl0.4
. H
-
Ein
<number>
, ein<angle>
oder das Schlüsselwortnone
(in diesem Fall äquivalent zu0deg
), das den<hue>
-Winkel der Ausgabefarbe darstellt. Siehe ein Beispiel für verschiedene Farbtöne im Abschnitt Beispiele unten. A
Optional-
Ein
<alpha-value>
Wert, der den Alphakanalwert der Ausgabefarbe darstellt, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig deckend) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit keinen Alphakanal anzugeben. Wenn derA
-Kanalwert nicht explizit angegeben ist, übernimmt er den Alphakanalwert der Ursprungsfarbe. Wenn er enthalten ist, wird der Wert durch einen Schrägstrich (/
) vorangestellt.
Definition der Ausgabekanalkomponenten von relativen Farben
Bei der Verwendung der relativen Farbsyntax innerhalb einer oklch()
-Funktion konvertiert der Browser die Ursprungsfarbe in eine äquivalente Oklch-Farbe (sofern sie nicht bereits als solche spezifiziert ist). Die Farbe wird als drei verschiedene Farbkanalwerte definiert — l
(Helligkeit), c
(Chroma) und h
(Farbton) — plus ein Alphakanalwert (alpha
). Diese Kanalwerte sind innerhalb der Funktion verfügbar, um bei der Definition der Ausgabefarbkanalwerte verwendet zu werden:
- Der
l
-Kanalwert wird zu einer<number>
zwischen0
und1
aufgelöst, inklusiv. - Der
c
-Kanalwert wird zu einer<number>
zwischen0
und0.4
aufgelöst, inklusiv. - Der
h
-Kanalwert wird zu einer<number>
zwischen0
und360
aufgelöst, inklusiv. - Der
alpha
-Kanal wird zu einer<number>
zwischen0
und1
aufgelöst, inklusiv.
Bei der Definition einer relativen Farbe können die verschiedenen Kanäle der Ausgabefarbe auf verschiedene Weise ausgedrückt werden. Nachfolgend werden einige Beispiele untersucht, um diese zu veranschaulichen.
In den ersten beiden Beispielen unten verwenden wir relative Farbsyntax. Jedoch geben das erste die gleiche Farbe wie die Ursprungsfarbe aus und das zweite gibt eine Farbe aus, die überhaupt nicht auf der Ursprungsfarbe basiert. Sie erstellen wirklich keine relativen Farben! In einer realen Codebasis würden Sie diese vermutlich niemals verwenden und stattdessen einen absoluten Farbwert verwenden. Wir haben diese Beispiele als Ausgangspunkt für das Lernen über relative oklch()
-Syntax aufgenommen.
Beginnen wir mit einer Ursprungsfarbe von hsl(0 100% 50%)
(entspricht red
). Die folgende Funktion gibt die gleiche Farbe wie die Ursprungsfarbe aus — sie verwendet die l
-, c
- und h
-Kanalwerte (0.627966
, 0.257704
und 29.2346
) der Ursprungsfarbe als Ausgabekanäle:
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 Ausgabekanäle, wodurch eine völlig andere Farbe entsteht, 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)
In diesem Beispiel:
- Wird die
hsl()
Ursprungsfarbe in eine äquivalenteoklch()
-Farbe konvertiert —oklch(0.627966 0.257704 29.2346)
. - Wird der
H
-Kanalwert der Ausgabefarbe auf denH
-Kanalwert deroklch()
-Ursprungsversion gesetzt —29.2346
. - Werden die
L
- undC
-Kanalwerte der Ausgabefarbe auf neue, nicht auf der Ursprungsfarbe basierende Werte gesetzt:0.8
und0.4
jeweils.
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 das gleiche Modell wie die Ausgabefarbe konvertiert, damit sie in einer kompatiblen Weise dargestellt werden kann (d.h. unter Verwendung der gleichen Kanäle).
In den bisherigen Beispielen in diesem Abschnitt wurden die Alphakanäle weder für die Ursprungs- noch die Ausgabefarben explizit angegeben. Wenn der Alphakanal der Ausgabefarbe nicht angegeben ist, entspricht er dem gleichen Wert wie der Alphakanal der Ursprungsfarbe. Wenn der Alphakanal der Ursprungsfarbe nicht angegeben ist (und es sich nicht um eine relative Farbe handelt), ist der Standardwert 1
. Daher sind der Ursprungs- und der Ausgabewert des Alphakanals in den obigen Beispielen 1
.
Werfen wir nun einen Blick auf einige Beispiele, die Werte für den Ursprungs- und Ausgabewert des Alphakanals spezifizieren. Das erste Beispiel spezifiziert den Ausgabewert des Alphakanals als dem Ursprungsalphakanalwert entsprechend, während das zweite einen anderen Ausgabewert des Alphakanals spezifiziert, der nicht mit dem Ursprungsalphakanalwert zusammenhängt.
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 das oklch()
-Äquivalent 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 zu <number>
-Werten aufgelöst werden, müssen Sie ihnen bei Berechnungen Zahlen hinzufügen, selbst in Fällen, in denen ein Kanal normalerweise <percentage>
, <angle>
oder andere Wertetypen akzeptieren würde. Das Hinzufügen eines <percentage>
zu einem <number>
, beispielsweise, funktioniert nicht.
Formale Syntax
Beispiele
Anpassen der Helligkeit einer Farbe
Dieses Beispiel zeigt den Effekt des Variierens des L
-Wertes (Helligkeit) der oklch()
-Funktionsnotation.
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
Anpassen der Farbintensität über Chroma
Das folgende Beispiel zeigt den Effekt des Variierens des C
-Wertes (Chroma) der oklch()
-Funktionsnotation, wobei die Farben an Intensität abnehmen, wenn der C
-Wert von vollständig gesättigt bis 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 Anfangsfarben Blau, Rot und Grün deklarieren wir sukzessiv kleinere Chroma-Werte: beginnend bei voller Farbsättigung mit dem hohen Wert von 0.4
(äquivalent zu 100%
) bis hinunter zu 0.01
(äquivalent zu 2%
), welches für alle 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%
verwendet und die gleichen Helligkeitswerte gehabt, wären alle Farben in demselben Grauton gewesen. In diesem Beispiel sind sie fast grau.
Farbtöne in oklch
Das folgende Beispiel zeigt Farbproben mit unterschiedlichen H
-Werten (Farbton) der oklch()
-Funktionsnotation.
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()
. Weitere Informationen finden Sie unter <hue>
. 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 den Effekt des Variierens des A
-Wertes (Alpha) der oklch()
-Farb-Funktion.
Die red
und red-alpha
Elemente überlappen sich mit dem #background-div
Element, um die Wirkung der Deckkraft zu demonstrieren.
Gibt man A
den Wert 0.4
, macht dies die Farbe zu 40% opak.
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
Verwenden von relativen 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 aufgehellte und abgedunkelte Varianten dieser --base-color
erhalten.
Diese Varianten werden mithilfe relativer Farben definiert — die benutzerdefinierte Eigenschaft Custom Property --base-color
wird in eine oklch()
-Funktion übergeben, und die Ausgabefarben haben ihren Helligkeitskanal modifiziert, um den gewünschten Effekt über eine calc()
-Funktion zu erzielen. Der aufgehellte Farbton hat 0.15
(15%) zur Helligkeit hinzugefügt, und der abgedunkelte Farbton hat 0.15
(15%) von der Helligkeit abgezogen.
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
Das Ergebnis ist wie folgt:
Spezifikationen
Specification |
---|
CSS Color Module Level 5 # relative-Oklch |
CSS Color Module Level 4 # ok-lab |
Browser-Kompatibilität
Siehe auch
- Liste aller Farbnotationen
- Verwendung von Relativen Farben
- CSS Farben Modul
<hue>
Datentyplch()
undoklab()
Farb-Funktionen- Interaktiver Beitrag über den OKLCH-Farbraum (2024)
- OKLCH in CSS: warum wir von RGB und HSL gewechselt sind (2024)
- Ein perceptueller Farbraum für die Bildverarbeitung (2020)