lab()
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 lab()
-Funktionalnotation drückt eine angegebene 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 Alpha-Transparenzwert 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 #123456 calc(l + 10) a b)
lab(from hsl(180 100% 50%) calc(l - 10) a b)
Werte
Unten finden Sie Beschreibungen der zugelassenen Werte sowohl für absolute als auch relative Farben.
Syntax von absoluten Werten
lab(L a b[ / A])
Die Parameter sind wie folgt:
L
-
Ein
<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
-
Ein
<number>
zwischen-125
und125
, ein<percentage>
zwischen-100%
und100%
oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert gibt die Entfernung der Farbe entlang dera
-Achse an, die definiert, wie grün (zurückgehend zu-125
) oder rot (zurückgehend zu+125
) die Farbe ist. Beachten Sie, dass diese Werte Vorzeichen haben (sowohl positive als auch negative Werte sind möglich) und theoretisch unbegrenzt sind, was bedeutet, dass Sie Werte außerhalb der±125
(±100%
) Limits festlegen können. In der Praxis können Werte±160
nicht überschreiten. b
-
Ein
<number>
zwischen-125
und125
, ein<percentage>
zwischen-100%
und100%
oder das Schlüsselwortnone
(entspricht in diesem Fall0%
). Dieser Wert gibt die Entfernung der Farbe entlang derb
-Achse an, die definiert, wie blau (zurückgehend zu-125
) oder gelb (zurückgehend zu+125
) die Farbe ist. Beachten Sie, dass diese Werte Vorzeichen haben (sowohl positive als auch negative Werte sind möglich) und theoretisch unbegrenzt sind, was bedeutet, dass Sie Werte außerhalb der±125
(±100%
) Limits festlegen können. In der Praxis können Werte±160
nicht überschreiten. A
Optional-
Ein
<alpha-value>
-Wert, der den Alpha-Kanalwert der Farbe darstellt, wobei die Zahl0
0%
(vollständig transparent) entspricht 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 ist, wird er standardmäßig auf 100% gesetzt. Wenn er enthalten ist, wird der Wert durch einen Schrägstrich (/
) vorangestellt.
Hinweis:
Weitere Informationen zur Wirkung von none
finden Sie unter Fehlende Farbkomponenten.
Relativwert-Syntax
lab(from <color> L a b[ / 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 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
und100
, ein<percentage>
zwischen0%
und100%
oder das Schlüsselwortnone
(entspricht0%
in diesem Fall). Dieser Wert repräsentiert die Helligkeit der Ausgabefarbe. Hier entspricht die Zahl0
0%
(schwarz) und die Zahl100
100%
(weiß). a
-
Ein
<number>
zwischen-125
und125
, ein<percentage>
zwischen-100%
und100%
oder das Schlüsselwortnone
(entspricht0%
in diesem Fall). Dieser Wert repräsentiert die Entfernung der Ausgabefarbe entlang dera
-Achse, die definiert, wie grün (zurückgehend zu-125
) oder rot (zurückgehend zu+125
) die Farbe ist. Beachten Sie, dass diese Werte Vorzeichen haben (sowohl positive als auch negative Werte sind möglich) und theoretisch unbegrenzt sind, was bedeutet, dass Sie Werte außerhalb der±125
(±100%
) Limits festlegen können. In der Praxis können Werte±160
nicht überschreiten. b
-
Ein
<number>
zwischen-125
und125
, ein<percentage>
zwischen-100%
und100%
oder das Schlüsselwortnone
(entspricht0%
in diesem Fall). Dieser Wert repräsentiert die Entfernung der Ausgabefarbe entlang derb
-Achse, die definiert, wie blau (zurückgehend zu-125
) oder gelb (zurückgehend zu+125
) die Farbe ist. Beachten Sie, dass diese Werte Vorzeichen haben (sowohl positive als auch negative Werte sind möglich) und theoretisch unbegrenzt sind, was bedeutet, dass Sie Werte außerhalb der±125
(±100%
) Limits festlegen können. In der Praxis können Werte±160
nicht überschreiten. A
Optional-
Ein
<alpha-value>
-Wert, der den Alpha-Kanalwert der Ausgabefarbe darstellt, wobei die Zahl0
0%
(vollständig transparent) entspricht 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 ist, entspricht er standardmäßig dem Alpha-Kanal-Wert der Ursprungsfarbe. Wenn er enthalten ist, wird der Wert durch einen Schrägstrich (/
) vorangestellt.
Hinweis:
Normalerweise, wenn Prozentwerte ein numerisches Äquivalent in CSS haben, entspricht 100%
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%
100
entspricht. Die a
- und b
-Werte unterstützen sowohl negative als auch positive Werte, wobei 100%
125
entspricht und -100%
-125
entspricht.
Definieren von relativen Farb-Outputkanalkomponenten
Beim Verwenden der relativen Farbsyntax innerhalb einer lab()
-Funktion konvertiert der Browser die Ursprungsfarbe in eine äquivalente Lab-Farbe (falls sie nicht bereits als solche angegeben ist). Die Farbe wird als drei verschiedene Farbausgangswerte definiert — l
(Helligkeit), a
(Grün/Rot-Achse) und b
(Blau/Gelb-Achse) — sowie ein Alpha-Kanalwert (alpha
). Diese Kanalwerte sind innerhalb der Funktion verfügbar, um bei der Definition der Ausgangsfarbkanalwerte verwendet zu werden:
- Der
l
-Kanalwert wird auf eine<number>
zwischen0
und100
aufgelöst, einschließlich. - Die
a
- undb
-Kanäle werden jeweils auf eine<number>
zwischen-125
und125
aufgelöst, einschließlich. - Der
alpha
-Kanal wird auf eine<number>
zwischen0
und1
aufgelöst, einschließlich.
Wenn eine relative Farbe definiert wird, können die verschiedenen Kanäle der Ausgabefarbe auf verschiedene Weise ausgedrückt werden. Unten werden wir einige Beispiele untersuchen, um diese zu veranschaulichen.
In den ersten beiden unten stehenden Beispielen verwenden wir die relative Farbsyntax. Das erste gibt jedoch die gleiche Farbe wie die Ursprungsfarbe aus und das zweite gibt eine Farbe aus, die überhaupt nicht auf der Ursprungsfarbe basiert. Sie machen wirklich keine relativen Farben! Es ist unwahrscheinlich, dass diese in einem echten Codeprojekt verwendet werden, und würden wahrscheinlich stattdessen einen absoluten Farbwert verwenden. Wir haben diese Beispiele als Ausgangspunkt für das Erlernen der relativen 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 die Ausgabekanalwerte:
lab(from hsl(0 100% 50%) l a b)
Die Ausgabe dieser Funktion ist lab(54.29 80.8198 69.8997)
.
Die nächste Funktion verwendet absolute Werte für die Ausgabekanalwerte und gibt 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 basierend auf der Ursprungsfarbe:
lab(from hsl(0 100% 50%) l -100 b)
Dieses Beispiel:
- Konvertiert die
hsl()
-Ursprungsfarbe in eine äquivalentelab()
-Farbe —lab(54.29 80.8198 69.8997)
. - Setzt die
l
- undb
-Kanalwerte für die Ausgabefarbe auf diejenigen der äquivalentenlab()
-Ursprungsfarbenwerte — diese Werte sind54.29
und69.8997
. - Setzt den
a
-Kanalwert der Ausgabefarbe auf einen neuen Wert, 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 das gleiche Modell wie die Ausgabefarbe umgewandelt, damit sie in einer kompatiblen Weise dargestellt werden kann (d.h. unter Verwendung der gleichen 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 spezifiziert. Wenn der Alpha-Kanal der Ausgabefarbe nicht spezifiziert ist, übernimmt er standardmäßig denselben Wert wie der Alpha-Kanal der Ursprungsfarbe. Wenn der Alpha-Kanal der Ursprungsfarbe nicht spezifiziert ist (und es sich nicht um eine relative Farbe handelt), ist der Standardwert 1
. Daher sind die Ursprungs- und Ausgabekanalwerte für den Alpha-Kanal 1
für die obigen Beispiele.
Sehen wir uns einige Beispiele an, in denen Ursprungs- und Ausgabekanalwerte explizit spezifiziert werden. Das erste Beispiel spezifiziert den Ausgabekanalwert als denselben wie den Ursprungsalphakanalwert, während das zweite Beispiel einen anderen Ausgabekanalwert angibt, der nicht mit dem Ursprungsalphakanalwert zusammenhängt.
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 wieder in das lab()
-Äquivalent konvertiert — 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 auf <number>
-Werte aufgelöst werden, müssen Sie Zahlen hinzufügen, wenn Sie diese in Berechnungen verwenden, selbst in Fällen, in denen ein Kanal normalerweise <percentage>
-, <angle>
- oder andere Werttypen akzeptieren würde. Ein <percentage>
zu einer <number>
hinzuzufügen, funktioniert zum Beispiel nicht.
Formale Syntax
<lab()> =
lab( [ <percentage> | <number> | none ] [ <percentage> | <number> | none ] [ <percentage> | <number> | none ] [ / [ <alpha-value> | none ] ]? )
<alpha-value> =
<number> |
<percentage>
Beispiele
>Anpassung der Helligkeit
Das folgende Beispiel zeigt die Auswirkung der Variation des Helligkeitswertes 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 demonstriert die Effekte der Einstellung der a
- und b
-Werte der lab()
-Funktion zu den Enden und Mittelpunkten der a-Achse, die von grün (-125) zu rot (125) verläuft, und der b-Achse, die von gelb (-125) zu blau (125) verläuft.
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
Mit der CSS-Eigenschaft background-color
variieren wir die a
- und b
-Werte der lab()
-Farb-Funktion entlang der a-Achse und b-Achse, um die Effekte 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 am blauen Ende (125). Die obere Reihe zeigt Farben am roten Ende der a-Achse (-125) und die untere Reihe am grünen Ende (125). Die mittlere Spalte und Reihe befinden sich an 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 b-Achse
Dieses Beispiel enthält lineare Verläufe, um die Fortschreitung der Werte der lab()
-Funktion entlang der a-Achse (von rot zu grün) und entlang der b-Achse (von gelb zu blau) zu demonstrieren. In jedem Farbverlaufsbild 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 Auswirkung der Variation des A
(Alpha)-Wertes der lab()
-Funktionalnotation. Die red
- und red-alpha
-Elemente überlappen das #background-div
-Element, um den Effekt der Deckkraft zu demonstrieren. Durch die Angabe eines A
-Wertes von 0.4
wird 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 relativer Farben mit lab()
Dieses Beispiel stylt drei <div>
-Elemente mit verschiedenen Hintergrundfarben. Das mittlere erhält die unveränderte --base-color
, während die linken und rechten aufgehellte beziehungsweise abgedunkelte Varianten dieser --base-color
erhalten.
Diese Varianten werden unter Verwendung relativer Farben definiert — die benutzerdefinierte Eigenschaft --base-color
wird an eine lab()
-Funktion übergeben, und die Ausgabefarben haben ihren Helligkeitskanal modifiziert, um den gewünschten Effekt über eine calc()
-Funktion zu erzielen. Die aufgehellte Farbe hat 15% zur Helligkeit hinzugefügt, und die abgedunkelte Farbe hat 15% von der Helligkeit abgezogen.
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
Die Ausgabe ist wie folgt:
Spezifikationen
Specification |
---|
CSS Color Module Level 5> # relative-Lab> |
CSS Color Module Level 4> # lab-colors> |
Browser-Kompatibilität
Loading…
Siehe auch
<color>
Datentyp<color-function>
Datentyp- Verwendung relativer Farben
- CSS-Farben Modul
- LCH-Farben in CSS: was, warum und wie? von Lea Verou (2020)
- Release Notes für Safari Technology Preview 122: enthält
lab()
undlch()
Farben