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 gegebene Farbe im Oklab-Farbraum aus. oklch()
ist die zylindrische Form von oklab()
, die dieselbe L
-Achse verwendet, jedoch 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 sind die Beschreibungen der zulässigen Werte für sowohl absolute als auch relative Farben aufgelistet.
Hinweis:
Normalerweise, wenn Prozentwerte in CSS eine numerische Entsprechung haben, ist 100%
gleich der Zahl 1
.
Dies trifft nicht auf alle oklch()
Komponentenwerte zu. Hier entspricht 100%
dem Wert 0.4
für den C
-Wert.
Absolute Wert-Syntax
oklch(L C H[ / A])
Die Parameter sind wie folgt:
L
-
Ein
<number>
zwischen0
und1
, ein<percentage>
zwischen0%
und100%
, oder das Schlüsselwortnone
(in diesem Fall gleichbedeutend mit0%
). In diesem Fall entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). Dieser Wert gibt die wahrgenommene Helligkeit oder "Helligkeit" der Farbe an.Hinweis: Das
L
inoklch()
ist die wahrgenommene Helligkeit, die sich auf die "Helligkeit" bezieht, die wir mit unseren Augen 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
(gleich0%
in diesem Fall). Dieser Wert ist ein Maß für die Chroma der Farbe (ungefähr die "Menge der Farbe"). Sein minimaler nützlicher Wert ist0
, während der maximale theoretisch unbegrenzt ist (praktisch jedoch nicht0.5
überschreitet). In diesem Fall ist0%
0
und100%
ist die Zahl0.4
. H
-
Ein
<number>
, ein<angle>
, oder das Schlüsselwortnone
(gleich0deg
in diesem Fall), das den<hue>
-Winkel der Farbe repräsentiert.Hinweis: Die Winkel, die bestimmten Farbtönen entsprechen, unterscheiden sich zwischen dem sRGB (verwendet von
hsl()
undhwb()
), CIELAB (verwendet vonlch()
) und Oklab (verwendet vonoklch()
) Farbräumen. Siehe das untenstehende Beispiel Farbtöne inoklch()
und die<hue>
Referenzseite für weitere Details und Beispiele. A
Optional-
Ein
<alpha-value>
, das den Alpha-Kanal-Wert der Farbe darstellt, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig undurchsichtig) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um ausdrücklich keinen Alpha-Kanal anzugeben. Wenn derA
-Kanalwert nicht ausdrücklich angegeben wird, beträgt er standardmäßig 100%. Wenn enthalten, wird der Wert durch einen Schrägstrich (/
) eingeleitet.
Hinweis:
Siehe Fehlende Farbkomponenten für weitere Informationen über die Wirkung von none
.
Relative Wert-Syntax
oklch(from <color> L C H[ / A])
Die Parameter sind wie folgt:
from <color>
-
Das Schlüsselwort
from
wird immer verwendet, 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
-
Ein
<number>
zwischen0
und1
, ein<percentage>
zwischen0%
und100%
, oder das Schlüsselwortnone
(gleichbedeutend mit0%
in diesem Fall). Dies repräsentiert den Helligkeitswert der Ausgabefarbe. Hier entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). C
-
Ein
<number>
, ein<percentage>
, oder das Schlüsselwortnone
(gleichbedeutend mit0%
in diesem Fall). Dieser Wert repräsentiert den Chromawert der Ausgabefarbe (ungefähr die "Menge der Farbe"). Sein minimaler nützlicher Wert ist0
, während sein maximaler theoretisch unbegrenzt ist (praktisch jedoch nicht0.5
überschreitet). In diesem Fall ist0%
0
und100%
ist die Zahl0.4
. H
-
Ein
<number>
, ein<angle>
, oder das Schlüsselwortnone
(gleichbedeutend mit0deg
in diesem Fall), das den<hue>
-Winkel der Ausgabefarbe repräsentiert. Siehe ein Beispiel für verschiedene Farbtöne im Abschnitt Beispiele unten. A
Optional-
Ein
<alpha-value>
, das den Alpha-Kanal-Wert der Ausgabefarbe darstellt, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig undurchsichtig) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um ausdrücklich keinen Alpha-Kanal anzugeben. Wenn derA
-Kanalwert nicht ausdrücklich angegeben wird, entspricht er standardmäßig dem Alpha-Kanal-Wert der Ursprungsfarbe. Wenn enthalten, wird der Wert durch einen Schrägstrich (/
) eingeleitet.
Definieren von Kanal-Komponenten für den Ausgabefarbkanal
Beim Verwenden der relativen Farbsyntax innerhalb einer oklch()
Funktion konvertiert der Browser die Ursprungsfarbe in eine gleichwertige Oklch-Farbe (wenn diese nicht bereits als solche angegeben ist). Die Farbe wird als drei verschiedene Farbkanalwerte definiert — l
(Helligkeit), c
(Chroma) und h
(Farbton) — sowie einen Alpha-Kanal-Wert (alpha
). Diese Kanalwerte stehen innerhalb der Funktion zur Verfügung, um beim Definieren der Ausgabefarbkanalwerte verwendet zu werden:
- Der
l
-Kanalwert wird zu einem<number>
zwischen0
und1
aufgelöst, einschließlich. - Der
c
-Kanalwert wird zu einem<number>
zwischen0
und0.4
aufgelöst, einschließlich. - Der
h
-Kanalwert wird zu einem<number>
zwischen0
und360
aufgelöst, einschließlich. - Der
alpha
-Kanal wird zu einem<number>
zwischen0
und1
aufgelöst, einschließlich.
Beim Definieren einer relativen Farbe können die verschiedenen Kanäle der Ausgabefarbe auf verschiedene Weisen ausgedrückt werden. Nachfolgend untersuchen wir einige Beispiele, 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 erzeugen eigentlich keine relativen Farben! Sie würden diese wahrscheinlich nie in einem echten Codebase verwenden und wahrscheinlich stattdessen nur einen absoluten Farbwert verwenden. Wir haben diese Beispiele als Ausgangspunkt zum Erlernen der relativen oklch()
-Syntax aufgenommen.
Lassen Sie uns mit einer Ursprungsfarbe von hsl(0 100% 50%)
(entspricht rot
) beginnen. Die folgende Funktion gibt dieselbe Farbe wie die Ursprungsfarbe aus — sie verwendet die l
, c
und h
Kanalwerte (0.627966
, 0.257704
und 29.2346
) der Ursprungsfarbe als Ausgabekanalwerte:
oklch(from hsl(0 100% 50%) l c h)
Diese Funktion ergibt die Ausgabefarbe 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 auf Basis der Ursprungsfarbe:
oklch(from hsl(0 100% 50%) 0.8 0.4 h)
Dieses Beispiel:
- Konvertiert die
hsl()
Ursprungsfarbe in eine gleichwertigeoklch()
-Farbe —oklch(0.627966 0.257704 29.2346)
. - Setzt den
H
-Kanalwert für die Ausgabefarbe auf denH
-Kanalwert der Ursprünglichkeitoklch()
-Äquivalente —29.2346
. - Legt die
L
- undC
-Kanalwerte der Ausgabefarbe auf neue Werte fest, die nicht auf der Ursprungsfarbe basieren:0.8
und0.4
.
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 konvertiert, damit sie in einer Weise dargestellt werden kann, die kompatibel ist (d.h. dieselben Kanäle verwendet).
In den bisherigen Beispielen in diesem Abschnitt wurden die Alpha-Kanäle weder für die Ursprungs- noch die Ausgabefarben ausdrücklich spezifiziert. Wenn der Alpha-Kanal der Ausgabefarbe nicht spezifiziert ist, entspricht er standardmäßig dem Wert des Alpha-Kanals der Ursprungsfarbe. Wenn der Alpha-Kanal der Ursprungsfarbe nicht angegeben ist (und es sich nicht um eine relative Farbe handelt), beträgt er standardmäßig 1
. Daher beträgt der Alpha-Kanalwert der Ursprungs- und Ausgabefarben in den obigen Beispielen 1
.
Lassen Sie uns einige Beispiele betrachten, die Ursprungs- und Ausgabefarbkanalwerte angeben. Das erste gibt den Alpha-Kanalwert der Ausgabefarbe an, der dem Alpha-Kanalwert der Ursprungsfarbe entspricht, während das zweite einen anderen Alpha-Kanalwert angibt, der nicht mit dem Alpha-Kanalwert der Ursprungsfarbe verwandt ist.
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)
. Auf die L
-, C
-, H
- und A
-Werte werden calc()
-Berechnungen 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 sind, müssen Sie Zahlen hinzufügen, wenn Sie sie in Berechnungen verwenden, selbst in Fällen, in denen ein Kanal normalerweise <percentage>
, <angle>
oder andere Werttypen akzeptieren würde. Das Hinzufügen einer <percentage>
zu einer <number>
, zum Beispiel, funktioniert nicht.
Formale Syntax
Beispiele
Anpassen der Helligkeit einer Farbe
Dieses Beispiel zeigt die Wirkung, die das Variieren des L
(Helligkeit)-Werts der oklch()
Funktionsnotation hat.
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 die Wirkung, die das Variieren des C
(Chroma)-Werts der oklch()
Funktionsnotation hat, wobei die Farben in der Intensität abnehmen, je mehr 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 Startfarben Blau, Rot und Grün deklarieren wir progressive kleinere Chroma-Werte für sie: beginnend bei voller Farbsättigung am hohen Wert von 0.4
(entspricht 100%
) bis 0.01
(entspricht 2%
), was 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 statt 0
0.01
und 2%
verwendet, wären bei gleichen Helligkeitswerten alle Farben der gleiche Grauton gewesen. In diesem Beispiel sind sie fast grau.
Farbtöne in oklch
Das folgende Beispiel zeigt Farbfelder mit unterschiedlichen H
(Farbton) Werten 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 Farbwinkel in oklch()
unterscheiden sich von denen in hsl()
. Weitere Informationen siehe <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 Alpha-Wertes einer Farbe
Das folgende Beispiel zeigt die Wirkung, die das Variieren des A
(Alpha)-Werts der oklch()
-Farbe hat.
Die red
- und red-alpha
-Elemente überlappen das #background-div
-Element, um die Wirkung der Deckkraft zu demonstrieren.
Ein A
-Wert von 0.4
macht die Farbe zu 40% undurchsichtig.
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 Element erhält die unveränderte --base-color
, während die linken und rechten Elemente aufgehellte und abgedunkelte Varianten dieser --base-color
erhalten.
Diese Varianten werden unter Verwendung relativer Farben definiert — die --base-color
benutzerdefinierte Eigenschaft wird in eine oklch()
Funktion übergeben, und die Ausgabefarben haben ihren Helligkeitskanal über eine calc()
Funktion so modifiziert, dass der gewünschte Effekt erzielt wird. Der aufgehellte Farbe wird 0.15
(15%) zum Helligkeitskanal hinzugefügt, und der abgedunkelten Farbe wird 0.15
(15%) vom Helligkeitskanal 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
Der Output 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 Farbnationen
- Verwendung relativer Farben
- CSS-Colormodul
<hue>
Datentyplch()
undoklab()
Farb-Funktionen- Interaktiver Beitrag zum OKLCH-Farbraum (2024)
- OKLCH in CSS: Warum wir von RGB und HSL gewechselt sind (2024)
- Ein perceptualer Farbraum für die Bildverarbeitung (2020)