lab()
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 lab()
funktionale Notation drückt eine gegebene Farbe im CIE L*a*b* Farbraum aus.
Lab repräsentiert das gesamte Spektrum der Farben, die Menschen sehen können, indem es die Helligkeit der Farbe, einen Rot/Grün-Achsenwert, einen Blau/Gelb-Achsenwert und einen optionalen Alphatransparenzwert angibt.
Syntax
/* Absolute values */
lab(29.2345% 39.3825 20.0664);
lab(52.2345% 40.1645 59.9971);
lab(52.2345% 40.1645 59.9971 / .5);
/* Relative values */
lab(from green l a b / 0.5)
lab(from #0000FF calc(l + 10) a b)
lab(from hsl(180 100% 50%) calc(l - 10) a b)
Werte
Nachfolgend finden Sie Beschreibungen der zulässigen Werte für sowohl absolute als auch relative Farben.
Syntax für absolute Werte
lab(L a b[ / A])
Die Parameter sind wie folgt:
L
-
Eine
<number>
zwischen0
und100
, ein<percentage>
zwischen0%
und100%
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert gibt die Helligkeit der Farbe an. Hier entspricht die Zahl0
0%
(schwarz) und die Zahl100
100%
(weiß). a
-
Eine
<number>
zwischen-125
und125
, ein<percentage>
zwischen-100%
und100%
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert gibt den Abstand der Farbe entlang dera
-Achse an, die definiert, wie grün (Richtung-125
) oder rot (Richtung+125
) die Farbe ist. Beachten Sie, dass diese Werte unterschrieben sind (sowohl positive als auch negative Werte sind zulässig) und theoretisch unbegrenzt sind, was bedeutet, dass Sie Werte außerhalb der±125
(±100%
) Grenzen setzen können. In der Praxis können die Werte±160
nicht überschreiten. b
-
Eine
<number>
zwischen-125
und125
, ein<percentage>
zwischen-100%
und100%
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert spezifiziert den Abstand der Farbe entlang derb
-Achse, die definiert, wie blau (Richtung-125
) oder gelb (Richtung+125
) die Farbe ist. Beachten Sie, dass diese Werte unterschrieben sind (sowohl positive als auch negative Werte sind zulässig) und theoretisch unbegrenzt sind, was bedeutet, dass Sie Werte außerhalb der±125
(±100%
) Grenzen setzen können. In der Praxis können die Werte±160
nicht überschreiten. A
Optional-
Ein
<alpha-value>
repräsentiert den Alphakanalwert der Farbe, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig undurchsichtig) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit keinen Alphakanal festzulegen. Wenn derA
-Kanalwert nicht explizit angegeben wird, ist der Standardwert 100%. Wenn eingeschlossen, wird der Wert von einem Schrägstrich (/
) vorangestellt.
Hinweis:
Weitere Informationen zur Wirkung von none
finden Sie unter Fehlende Farbkomponenten.
Syntax für relative Werte
lab(from <color> L a b[ / A])
Die Parameter sind wie folgt:
from <color>
-
Das Schlüsselwort
from
wird immer angegeben, 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
und100
, ein<percentage>
zwischen0%
und100%
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert repräsentiert die Helligkeit der Ausgabefarbe. Hier entspricht die Zahl0
0%
(schwarz) und die Zahl100
100%
(weiß). a
-
Eine
<number>
zwischen-125
und125
, ein<percentage>
zwischen-100%
und100%
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert repräsentiert den Abstand der Ausgabefarbe entlang dera
-Achse, die definiert, wie grün (Richtung-125
) oder rot (Richtung+125
) die Farbe ist. Beachten Sie, dass diese Werte unterschrieben sind (sowohl positive als auch negative Werte sind zulässig) und theoretisch unbegrenzt sind, was bedeutet, dass Sie Werte außerhalb der±125
(±100%
) Grenzen setzen können. In der Praxis können die Werte±160
nicht überschreiten. b
-
Eine
<number>
zwischen-125
und125
, ein<percentage>
zwischen-100%
und100%
, oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert repräsentiert den Abstand der Ausgabefarbe entlang derb
-Achse, die definiert, wie blau (Richtung-125
) oder gelb (Richtung+125
) die Farbe ist. Beachten Sie, dass diese Werte unterschrieben sind (sowohl positive als auch negative Werte sind zulässig) und theoretisch unbegrenzt sind, was bedeutet, dass Sie Werte außerhalb der±125
(±100%
) Grenzen setzen können. In der Praxis können die Werte±160
nicht überschreiten. A
Optional-
Ein
<alpha-value>
repräsentiert den Alphakanalwert der Ausgabefarbe, wobei die Zahl0
0%
(vollständig transparent) und1
100%
(vollständig undurchsichtig) entspricht. Zusätzlich kann das Schlüsselwortnone
verwendet werden, um explizit keinen Alphakanal festzulegen. Wenn derA
-Kanalwert nicht explizit angegeben wird, ist der Standardwert der des Alphakanals der Ursprungsfarbe. Wenn eingeschlossen, wird der Wert von einem Schrägstrich (/
) vorangestellt.
Hinweis:
Normalerweise ist, wenn Prozentwerte in CSS eine numerische Entsprechung haben, 100%
gleich der Zahl 1
. Dies ist nicht immer der Fall für die Helligkeit von LAB und die a
- und b
-Achsen, wie oben erwähnt. Bei L
reicht der Bereich von 0 bis 100, wobei 100%
gleich 100
ist. Die a
- und b
-Werte unterstützen sowohl negative als auch positive Werte, wobei 100%
gleich 125
und -100%
gleich -125
ist.
Definition von Ausgabekanalwerten für relative Farben
Wenn die relative Farbsyntax innerhalb einer lab()
-Funktion verwendet wird, wandelt der Browser die Ursprungsfarbe in eine gleichwertige Lab-Farbe um (falls sie nicht bereits als solche angegeben ist). Die Farbe wird als drei unterschiedliche Farbkanalwerte definiert — l
(Helligkeit), a
(Grün/Rot-Achse) und b
(Blau/Gelb-Achse) — plus einem Alphakanalwert (alpha
). Diese Kanalwerte stehen innerhalb der Funktion zur Verfügung, um sie bei der Definition der Ausgabefarbkanalwerte zu verwenden:
- Der
l
-Kanalwert wird in eine<number>
zwischen0
und100
, inklusive, aufgelöst. - Die
a
- undb
-Kanäle werden jeweils in eine<number>
zwischen-125
und125
, inklusive, aufgelöst. - Der
alpha
-Kanal wird in eine<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. Nachfolgend werden wir einige Beispiele betrachten, um diese zu veranschaulichen.
In den ersten beiden Beispielen unten verwenden wir relative Farbsyntax. Die erste gibt jedoch die gleiche Farbe wie die Ursprungsfarbe aus, und die 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 einer echten Codebasis verwenden und stattdessen einfach einen absoluten Farbwert verwenden. Wir haben diese Beispiele als Ausgangspunkt für das Lernen über die relative lab()
-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
, a
, und b
-Kanalwerte der Ursprungsfarbe (54.29
, 80.8198
, und 69.8997
) als Ausgabekanalwerte:
lab(from hsl(0 100% 50%) l a b)
Die Ausgabe dieser Funktion ist die Farbe lab(54.29 80.8198 69.8997)
.
Die nächste Funktion verwendet absolute Werte für die Ausgabefarbkanalwerte und gibt damit eine völlig andere Farbe aus, die nicht auf der Ursprungsfarbe basiert:
lab(from hsl(0 100% 50%) 29.692% 44.89% -29.034%)
In diesem Fall ist die ausgegebene Farbe lab(29.692 56.1125 -36.2925)
.
Die folgende Funktion erzeugt eine relative Farbe, die auf der Ursprungsfarbe basiert:
lab(from hsl(0 100% 50%) l -100 b)
Dieses Beispiel:
- Wandelt die
hsl()
-Ursprungsfarbe in eine gleichwertigelab()
-Farbe um —lab(54.29 80.8198 69.8997)
. - Legt die
l
- undb
-Kanalwerte für die Ausgabefarbe auf dieL
- undb
-Kanalwerte des gleichwertigenlab()
der Ursprungsfarbe fest — diese Werte sind54.29
und69.8997
. - Legt den
a
-Kanalwert der Ausgabefarbe auf einen neuen Wert fest, der nicht auf der Ursprungsfarbe basiert:-100
.
Die endgültige Ausgabefarbe ist lab(54.29 -100 69.8997)
.
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, 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 Alphakanäle weder für die Ursprungs- noch für die Ausgabefarben explizit festgelegt. Wenn der Alphakanal der Ausgabefarbe nicht angegeben wird, übernimmt er standardmäßig denselben Wert wie der Alphakanal der Ursprungsfarbe. Wenn der Alphakanal der Ursprungsfarbe nicht angegeben ist (und es sich nicht um eine relative Farbe handelt), wird 1
als Standardwert verwendet. Daher ist der Alpha-Kanalwert der Ursprung- und Ausgabefarbe für die obigen Beispiele 1
.
Betrachten Sie einige Beispiele, die Ursprungs- und Ausgabewerte des Alphakanals angeben. Das erste Beispiel legt den Ausgabewert des Alphakanals so fest, dass er mit dem Ursprungswert des Alphakanals übereinstimmt, während das zweite Beispiel einen anderen Ausgabewert des Alphakanals angibt, der nicht auf dem Ursprungswert des Alphakanals basiert.
lab(from hsl(0 100% 50% / 0.8) l a b / alpha)
/* Computed output color: lab(54.29 80.8198 69.8997 / 0.8) */
lab(from hsl(0 100% 50% / 0.8) l a b / 0.5)
/* Computed output color: lab(54.29 80.8198 69.8997 / 0.5) */
Im folgenden Beispiel wird die hsl()
-Ursprungsfarbe erneut in das äquivalente lab()
umgewandelt — lab(54.29 80.8198 69.8997)
. calc()
-Berechnungen werden auf die L
-, a
-, b
-, und A
-Werte angewendet, was zu einer Ausgabefarbe von lab(74.29 60.8198 29.8997 / 0.9)
führt:
lab(from hsl(0 100% 50%) calc(l + 20) calc(a - 20) calc(b - 40) / calc(alpha - 0.1))
Hinweis:
Da die Ursprungsfarbkanalwerte in <number>
-Werte aufgelöst werden, müssen Sie Zahlen zu ihnen hinzufügen, 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 einer <number>
, funktioniert beispielsweise nicht.
Formale Syntax
Beispiele
Anpassung der Helligkeit
Das folgende Beispiel zeigt die Wirkung von variierenden Helligkeitswerten der lab()
-Funktion.
HTML
<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>
<div data-color="blue-dark"></div>
<div data-color="blue"></div>
<div data-color="blue-light"></div>
CSS
[data-color="red-dark"] {
background-color: lab(5 125 71);
}
[data-color="red"] {
background-color: lab(40 125 71);
}
[data-color="red-light"] {
background-color: lab(95 125 71);
}
[data-color="green-dark"] {
background-color: lab(10% -120 125);
}
[data-color="green"] {
background-color: lab(50% -120 125);
}
[data-color="green-light"] {
background-color: lab(90% -120 125);
}
[data-color="blue-dark"] {
background-color: lab(10 -120 -120);
}
[data-color="blue"] {
background-color: lab(50 -120 -120);
}
[data-color="blue-light"] {
background-color: lab(90 -120 -120);
}
Ergebnis
Anpassung der Farbachsen
Dieses Beispiel zeigt die Auswirkungen der Festlegung der a
- und b
-Werte der lab()
-Funktion auf die Enden und Mittelpunkte der a-Achse, die von grün (-125) bis rot (125) und der b-Achse, die von gelb (-125) bis blau (125) reicht.
HTML
<div data-color="red-yellow"></div>
<div data-color="red-zero"></div>
<div data-color="red-blue"></div>
<div data-color="zero-yellow"></div>
<div data-color="zero-zero"></div>
<div data-color="zero-blue"></div>
<div data-color="green-yellow"></div>
<div data-color="green-zero"></div>
<div data-color="green-blue"></div>
CSS
Unter Verwendung der CSS-Eigenschaft background-color
variieren wir die a
- und b
-Werte der lab()
-Farb-Funktion entlang der a-Achse und der b-Achse, um die Auswirkungen von maximalen, mittleren und minimalen Werten in jedem Fall zu zeigen.
/* a-axis max, variable b-axis */
[data-color="red-yellow"] {
background-color: lab(50 125 125);
}
[data-color="red-zero"] {
background-color: lab(50 125 0);
}
[data-color="red-blue"] {
background-color: lab(50 125 -125);
}
/* a-axis center, variable b-axis */
[data-color="zero-yellow"] {
background-color: lab(50 0 125);
}
[data-color="zero-zero"] {
background-color: lab(50 0 0);
}
[data-color="zero-blue"] {
background-color: lab(50 0 -125);
}
/* a-axis min, variable b-axis */
[data-color="green-yellow"] {
background-color: lab(50 -125 125);
}
[data-color="green-zero"] {
background-color: lab(50 -125 0);
}
[data-color="green-blue"] {
background-color: lab(50 -125 -125);
}
Ergebnis
Die linke Spalte ist am gelben Ende (-125) der b-Achse und die rechte Spalte ist am blauen Ende (125). Die obere Reihe zeigt Farben am roten Ende der a-Achse (-125) und die untere Reihe ist am grünen Ende (125). Die mittlere Spalte und Reihen befinden sich in den Mittelpunkten (0) jeder Achse, wobei die mittlere Zelle grau ist; sie enthält kein Rot, Grün, Gelb, oder Blau, mit einem 0
-Wert für beide Achsen.
Lineare Verläufe entlang der a-Achse und der b-Achse
Dieses Beispiel umfasst lineare Verläufe, um den Fortschritt der lab()
-Funktionswerte entlang der a-Achse (von Rot zu Grün) und entlang der b-Achse (von Gelb zu Blau) zu demonstrieren. In jedem Gradientenbild bleibt eine Achse statisch, während die andere Achse vom unteren Ende zum oberen Ende der Achsenwerte fortschreitet.
CSS
/* a-axis gradients */
[data-color="red-to-green-yellow"] {
background-image: linear-gradient(to right, lab(50 125 125), lab(50 -125 125));
}
[data-color="red-to-green-zero"] {
background-image: linear-gradient(to right, lab(50 125 0), lab(50 -125 0));
}
[data-color="red-to-green-blue"] {
background-image: linear-gradient(to right, lab(50 125 -125), lab(50 -125 -125));
}
/* b-axis gradients */
[data-color="yellow-to-blue-red"] {
background-image: linear-gradient(to right, lab(50 125 125), lab(50 125 -125));
}
[data-color="yellow-to-blue-zero"] {
background-image: linear-gradient(to right, lab(50 0 125), lab(50 0 -125));
}
[data-color="yellow-to-blue-green"] {
background-image: linear-gradient(to right, lab(50 -125 125),lab(50 -125 -125));
}
Ergebnis
Anpassung der Deckkraft
Das folgende Beispiel zeigt die Wirkung von variierenden A
(Alpha)-Werten der lab()
-funktionalen Notation. Die red
- und red-alpha
-Elemente überlappen das #background-div
-Element, um die Wirkung der Opazität 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: lab(80 125 125);
}
[data-color="red-alpha"] {
background-color: lab(80 125 125 / 0.4);
}
Ergebnis
Verwendung von relativen Farben mit lab()
Dieses Beispiel formatiert drei <div>
-Elemente mit unterschiedlichen Hintergrundfarben. Das mittlere erhält die nicht modifizierte --base-color
, während das linke und das rechte eine hellere und eine dunklere Variante dieser --base-color
erhalten.
Diese Varianten werden unter Verwendung von relativen Farben definiert — die --base-color
benutzerdefinierte Eigenschaft wird in eine lab()
-Funktion eingespeist, und die Ausgabefarben haben ihren Helligkeitskanal modifiziert, um den gewünschten Effekt mittels einer calc()
-Funktion zu erzielen. Die hellere Farbe hat 15% zum Helligkeitskanal hinzugefügt, und die dunklere Farbe hat 15% subtrahiert.
CSS
:root {
--base-color: orange;
/* equivalent of lab(75 24 79) */
}
#one {
background-color: lab(from var(--base-color) calc(l + 15) a b);
}
#two {
background-color: var(--base-color);
}
#three {
background-color: lab(from var(--base-color) calc(l - 15) a b);
}
Ergebnis
Das Ergebnis ist wie folgt:
Spezifikationen
Specification |
---|
CSS Color Module Level 5 # relative-Lab |
CSS Color Module Level 4 # lab-colors |
Browser-Kompatibilität
BCD tables only load in the browser
Siehe auch
<color>
Datentyp<color-function>
Datentyp- Verwendung von relativen Farben
- CSS-Farben Modul
- LCH Farben in CSS: was, warum und wie? von Lea Verou (2020)
- Safari Technology Preview 122 Veröffentlichungshinweise: beinhaltet
lab()
undlch()
Farben