空腹喝可乐有什么危害

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 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

css
/* 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> zwischen 0 und 1, ein <percentage> zwischen 0% und 100%, oder das Schlüsselwort none (in diesem Fall gleichbedeutend mit 0%). In diesem Fall entspricht die Zahl 0 0% (schwarz) und die Zahl 1 100% (wei?). Dieser Wert gibt die wahrgenommene Helligkeit oder "Helligkeit" der Farbe an.

Hinweis: Das L in oklch() ist die wahrgenommene Helligkeit, die sich auf die "Helligkeit" bezieht, die wir mit unseren Augen wahrnehmen. Dies unterscheidet sich vom L in hsl(), wo es die Helligkeit im Vergleich zu anderen Farben darstellt.

C

Ein <number>, ein <percentage>, oder das Schlüsselwort none (gleich 0% 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 ist 0, w?hrend der maximale theoretisch unbegrenzt ist (praktisch jedoch nicht 0.5 überschreitet). In diesem Fall ist 0% 0 und 100% ist die Zahl 0.4.

H

Ein <number>, ein <angle>, oder das Schlüsselwort none (gleich 0deg 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() und hwb()), CIELAB (verwendet von lch()) und Oklab (verwendet von oklch()) Farbr?umen. Siehe das untenstehende Beispiel Farbt?ne in oklch() 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 Zahl 0 0% (vollst?ndig transparent) und 1 100% (vollst?ndig undurchsichtig) entspricht. Zus?tzlich kann das Schlüsselwort none verwendet werden, um ausdrücklich keinen Alpha-Kanal anzugeben. Wenn der A-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> zwischen 0 und 1, ein <percentage> zwischen 0% und 100%, oder das Schlüsselwort none (gleichbedeutend mit 0% in diesem Fall). Dies repr?sentiert den Helligkeitswert der Ausgabefarbe. Hier entspricht die Zahl 0 0% (schwarz) und die Zahl 1 100% (wei?).

C

Ein <number>, ein <percentage>, oder das Schlüsselwort none (gleichbedeutend mit 0% in diesem Fall). Dieser Wert repr?sentiert den Chromawert der Ausgabefarbe (ungef?hr die "Menge der Farbe"). Sein minimaler nützlicher Wert ist 0, w?hrend sein maximaler theoretisch unbegrenzt ist (praktisch jedoch nicht 0.5 überschreitet). In diesem Fall ist 0% 0 und 100% ist die Zahl 0.4.

H

Ein <number>, ein <angle>, oder das Schlüsselwort none (gleichbedeutend mit 0deg 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 Zahl 0 0% (vollst?ndig transparent) und 1 100% (vollst?ndig undurchsichtig) entspricht. Zus?tzlich kann das Schlüsselwort none verwendet werden, um ausdrücklich keinen Alpha-Kanal anzugeben. Wenn der A-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> zwischen 0 und 1 aufgel?st, einschlie?lich.
  • Der c-Kanalwert wird zu einem <number> zwischen 0 und 0.4 aufgel?st, einschlie?lich.
  • Der h-Kanalwert wird zu einem <number> zwischen 0 und 360 aufgel?st, einschlie?lich.
  • Der alpha-Kanal wird zu einem <number> zwischen 0 und 1 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:

css
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:

css
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:

css
oklch(from hsl(0 100% 50%) 0.8 0.4 h)

Dieses Beispiel:

  • Konvertiert die hsl() Ursprungsfarbe in eine gleichwertige oklch()-Farbe — oklch(0.627966 0.257704 29.2346).
  • Setzt den H-Kanalwert für die Ausgabefarbe auf den H-Kanalwert der Ursprünglichkeit oklch()-?quivalente — 29.2346.
  • Legt die L- und C-Kanalwerte der Ausgabefarbe auf neue Werte fest, die nicht auf der Ursprungsfarbe basieren: 0.8 und 0.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.

css
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:

css
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

<oklch()> = 
oklch( [ <percentage> | <number> | none ] [ <percentage> | <number> | none ] [ <hue> | none ] [ / [ <alpha-value> | none ] ]? )

<hue> =
<number> |
<angle>

<alpha-value> =
<number> |
<percentage>

Beispiele

Anpassen der Helligkeit einer Farbe

Dieses Beispiel zeigt die Wirkung, die das Variieren des L (Helligkeit)-Werts der oklch() Funktionsnotation hat.

HTML

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

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

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.

css
[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

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

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

html
<div id="background-div">
  <div data-color="red"></div>
  <div data-color="red-alpha"></div>
</div>

CSS

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

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