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()
funktionale Notation gibt eine Farbe im Oklab-Farbraum an. oklch()
ist die zylindrische Form von oklab()
, und verwendet dieselbe L
-Achse, 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
Unten sind Beschreibungen der erlaubten Werte sowohl für absolute als auch für relative Farben aufgeführt.
Hinweis:
Üblicherweise, wenn Prozentwerte in CSS eine numerische Entsprechung haben, ist 100%
gleich der Zahl 1
.
Dies ist nicht der Fall für alle oklch()
-Komponentenwerte. Hier entspricht 100%
dem Wert 0.4
für den C
-Wert.
Syntax für absolute Werte
oklch(L C H[ / A])
Die Parameter sind wie folgt:
L
-
Eine
<number>
zwischen0
und1
, ein<percentage>
zwischen0%
und100%
oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). In diesem Fall entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). Dieser Wert bestimmt die wahrgenommene Helligkeit oder "Lichtstärke" der Farbe.Hinweis: Das
L
inoklch()
ist die wahrgenommene Helligkeit, die sich auf die "Lichtstärke" bezieht, die wir mit unseren Augen wahrnehmen. Dies unterscheidet sich von demL
inhsl()
, wo es die Helligkeit im Vergleich zu anderen Farben beschreibt. C
-
Eine
<number>
, ein<percentage>
oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert ist ein Maß für das Chroma der Farbe (entspricht in etwa der "Farbmenge"). Sein minimaler nützlicher Wert ist0
, während das Maximum theoretisch unbegrenzt ist (in der Praxis jedoch0.5
nicht überschreitet). In diesem Fall ist0%
gleich0
und100%
ist die Zahl0.4
. H
-
Ein
<number>
, ein<angle>
oder das Schlüsselwortnone
(entspricht in diesem Fall0deg
), das den<hue>
-Winkel der Farbe darstellt.Hinweis: Die Winkel, die bestimmten Farbtönen entsprechen, unterscheiden sich im 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 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 explizit keinen Alpha-Kanal anzugeben. Wenn derA
-Kanalwert nicht explizit angegeben wird, ist der Standardwert 100%. Wenn enthalten, wird der Wert mit einem Schrägstrich (/
) eingeleitet.
Hinweis:
Siehe Fehlende Farbkomponenten für weitere Informationen über die Wirkung von none
.
Syntax für relative Werte
oklch(from <color> L C H[ / A])
Die Parameter sind wie folgt:
from <color>
-
Das Schlüsselwort
from
ist immer enthalten, wenn eine relative Farbe definiert wird, gefolgt von einem<color>
-Wert, der die Ursprungsfarbe darstellt: Dies ist die Originalfarbe, 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
(entspricht in diesem Fall0%
). Dies stellt den Helligkeitswert der Ausgabefarbe dar. Hier entspricht die Zahl0
0%
(schwarz) und die Zahl1
100%
(weiß). C
-
Eine
<number>
, ein<percentage>
oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert stellt den Chroma-Wert der Ausgabefarbe dar (entspricht in etwa der "Farbmenge"). Sein minimaler nützlicher Wert ist0
, während sein Maximum theoretisch unbegrenzt ist (in der Praxis jedoch0.5
nicht überschreitet). In diesem Fall ist0%
gleich0
und100%
ist die Zahl0.4
. H
-
Ein
<number>
, ein<angle>
oder das Schlüsselwortnone
(entspricht in diesem Fall0deg
), das den<hue>
-Winkel der Ausgabefarbe darstellt. Sehen Sie sich ein Beispiel für verschiedene Farbtöne im Abschnitt Beispiele unten an. A
Optional-
Ein
<alpha-value>
, der 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 explizit keinen Alpha-Kanal anzugeben. Wenn derA
-Kanalwert nicht explizit angegeben wird, ist der Standardwert der Alpha-Kanal-Wert der Ursprungsfarbe. Wenn enthalten, wird der Wert mit einem Schrägstrich (/
) eingeleitet.
Definition der Ausgabekanal-Komponenten für relative Farben
Wenn eine relative Farbsyntax innerhalb einer oklch()
-Funktion verwendet wird, konvertiert der Browser die Ursprungsfarbe in eine äquivalente Oklch-Farbe (wenn sie nicht bereits so angegeben ist). Die Farbe wird als drei verschiedene Farbkanalwerte definiert — l
(Helligkeit), c
(Chroma) und h
(Farbton) — sowie ein Alpha-Kanal-Wert (alpha
). Diese Kanalwerte stehen innerhalb der Funktion zur Verfügung, um sie bei der Definition der Ausgabefarbkanalwerte zu verwenden:
- Der
l
-Kanalwert wird auf einen<number>
zwischen0
und1
, einschließlich, aufgelöst. - Der
c
-Kanalwert wird auf einen<number>
zwischen0
und0.4
, einschließlich, aufgelöst. - Der
h
-Kanalwert wird auf einen<number>
zwischen0
und360
, einschließlich, aufgelöst. - Der
alpha
-Kanal wird auf einen<number>
zwischen0
und1
, einschließlich, aufgelöst.
Bei der Definition einer relativen Farbe können die verschiedenen Kanäle der Ausgabefarbe auf mehrere Arten ausgedrückt werden. Unten werden wir einige Beispiele untersuchen, um diese zu veranschaulichen.
In den ersten beiden Beispielen unten verwenden wir die Syntax für relative Farben. Allerdings gibt das erste Beispiel dieselbe Farbe wie die Ursprungsfarbe aus und das zweite gibt eine Farbe aus, die nicht auf der Ursprungsfarbe basiert. Sie erzeugen tatsächlich keine relativen Farben! Es ist unwahrscheinlich, dass Sie diese jemals in einem echten Codebasis verwenden würden, und Sie würden wahrscheinlich stattdessen einen absoluten Farbwert verwenden. Wir haben diese Beispiele als Ausgangspunkt zum Lernen über die relative oklch()
-Syntax aufgenommen.
Beginnen wir mit einer Ursprungsfarbe von hsl(0 100% 50%)
(entspricht red
). 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)
Die Ausgabe dieser Funktion ist 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 für die Ausgabefarbe auf denH
-Kanalwert deroklch()
-Äquivalenz der Ursprungsfarbe —29.2346
. - Setzt die
L
- undC
-Kanalwerte der Ausgabefarbe auf neue Werte, die nicht auf der Ursprungsfarbe basieren:0.8
und0.4
jeweils.
Die finale 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 kompatiblen Weise dargestellt werden kann (d.h. unter Verwendung derselben Kanäle).
In den bisher in diesem Abschnitt gesehenen Beispielen wurden die Alpha-Kanäle weder für die Ursprungs- noch für die Ausgabefarben explizit angegeben. Wenn der Alpha-Kanal der Ausgabefarbe nicht angegeben ist, entspricht er standardmäßig demselben Wert wie der Alpha-Kanal der Ursprungsfarbe. Wenn der Alpha-Kanal der Ursprungsfarbe nicht angegeben ist (und es sich nicht um eine relative Farbe handelt), beträgt der Standardwert 1
. Daher haben die Ursprungs- und Ausgabefarbkanalwerte der obigen Beispiele den Wert 1
.
Schauen wir uns einige Beispiele an, die Ursprungs- und Ausgabefarbkanalwerte angeben. Das erste Beispiel spezifiziert den Ausgabekanalwert als denselben wie der der Ursprungsfarbe, während das zweite Beispiel einen anderen Ausgabekanalwert angibt, der nicht mit dem der Ursprungsfarbe 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 die oklch()
Äquivalenz konvertiert — oklch(0.627966 0.257704 29.2346)
. calc()
Berechnungen werden auf die L
-, C
-, H
- und A
-Werte angewendet, wodurch eine Ausgabefarbe von oklch(0.827966 0.357704 9.23462 / 0.9)
entsteht:
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 hinzuzufügen, wenn Sie sie in Berechnungen verwenden, sogar in Fällen, in denen ein Kanal normalerweise <percentage>
, <angle>
oder andere Wertetypen akzeptieren würde. Es funktioniert zum Beispiel nicht, ein <percentage>
zu einem <number>
hinzuzufügen.
Formale Syntax
Beispiele
Die Helligkeit einer Farbe einstellen
Dieses Beispiel zeigt die Wirkung des Variierens 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
Die Farbintensität über Chroma einstellen
Das folgende Beispiel zeigt die Wirkung des Variierens des C
(Chroma)-Wertes der oklch()
funktionalen Notation, mit Farben, die an Intensität abnehmen, wenn der C
-Wert von voll 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 anfänglichen Ausgangsfarben Blau, Rot und Grün deklarieren wir schrittweise kleinere Werte für Chroma: Beginnend bei voller Farbsättigung mit dem 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
Wenn wir 0
anstelle von 0.01
und 2%
verwendet hätten, bei denselben Helligkeitswerten, wären die Farben alle derselbe 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()
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 hingegen entspricht 0deg
Magenta, während Rot etwa 41deg
ist.
Den Alphawert einer Farbe einstellen
Das folgende Beispiel zeigt die Wirkung des Variierens des A
(Alpha)-Wertes der oklch()
-Farbfunktion.
Die red
- und red-alpha
-Elemente überlappen das #background-div
-Element, um den Effekt der Deckkraft zu demonstrieren.
Wenn man A
den Wert 0.4
gibt, macht dies 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 stylt drei <div>
-Elemente mit unterschiedlichen Hintergrundfarben. Das mittlere wird mit der unveränderten --base-color
versehen, während die linken und rechten hellere bzw. dunklere Varianten dieser --base-color
erhalten.
Diese Varianten werden mit relativen Farben definiert — die --base-color
benutzerdefinierte Eigenschaft wird in eine oklch()
-Funktion übergeben, und die Ausgabefarbkanalwerte werden modifiziert, um den gewünschten Effekt über eine calc()
-Funktion zu erzielen. Der aufgehellte Farbton erhält 0.15
(15%) zum Helligkeitskanal addiert, und der verdunkelte Farbton erhält 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
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 relativer Farben
- CSS-Farben Modul
<hue>
Datentyplch()
undoklab()
Farb-Funktionen- Interaktiver Beitrag zum OKLCH-Farbraum (2024)
- OKLCH in CSS: warum wir von RGB und HSL umgestiegen sind (2024)
- Ein wahrnehmungsbasierter Farbraum für die Bildverarbeitung (2020)