background-clip
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
* Some parts of this feature may have varying levels of support.
Die background-clip
CSS Eigenschaft legt fest, ob der Hintergrund eines Elements sich unter der Border-Box, Padding-Box oder Content-Box erstreckt.
Probieren Sie es aus
background-clip: border-box;
background-clip: padding-box;
background-clip: content-box;
background-clip: text;
color: transparent;
text-shadow: none;
<section id="default-example">
<div id="example-element">This is the content of the element.</div>
</section>
#example-element {
background-image: url("/shared-assets/images/examples/leopard.jpg");
color: white;
text-shadow: 2px 2px black;
padding: 20px;
border: 10px dashed #333;
font-size: 2em;
font-weight: bold;
}
Der Hintergrund wird immer hinter dem Rand gezeichnet, daher hat background-clip: border-box
nur dann einen visuellen Effekt, wenn der Rand teilweise undurchsichtig ist oder transparente oder teilweise durchsichtige Bereiche aufweist. Auch die Eigenschaft background-clip: text
hat wenig bis keinen visuellen Effekt, wenn der Text vollständig oder teilweise undurchsichtig ist.
Hinweis:
Da das Stammelement einen anderen Hintergrund-Malbereich hat, hat die Eigenschaft background-clip
keine Wirkung, wenn sie darauf angegeben wird. Siehe "The backgrounds of special elements."
Hinweis:
Für Dokumente, deren Stammelement ein HTML-Element ist: wenn der berechnete Wert von background-image
auf dem Stammelement none
ist und dessen background-color
transparent
ist, müssen Benutzeragenten stattdessen die berechneten Werte der background
-Eigenschaften vom ersten HTML <body>
Kind-Element dieses Elements übernehmen. Die verwendeten Werte der background
-Eigenschaften dieses <body>
-Elements sind ihre Anfangswerte, und die übernommenen Werte werden so behandelt, als ob sie auf dem Stammelement angegeben wurden. Es wird empfohlen, dass Autoren von HTML-Dokumenten den Hintergrund des Canvas für das <body>
-Element anstelle des HTML-Elements angeben.
Syntax
/* Keyword values */
background-clip: border-box;
background-clip: padding-box;
background-clip: content-box;
background-clip: text;
background-clip: border-area;
/* Global values */
background-clip: inherit;
background-clip: initial;
background-clip: revert;
background-clip: revert-layer;
background-clip: unset;
Werte
border-box
-
Der Hintergrund erstreckt sich bis zum äußeren Rand der Grenze (aber unter der Grenze in z-Reihenfolge).
padding-box
-
Der Hintergrund erstreckt sich bis zum äußeren Rand des Paddings. Kein Hintergrund wird unter der Grenze gezeichnet.
content-box
-
Der Hintergrund wird innerhalb der Content-Box gemalt (eingeschnitten).
text
-
Der Hintergrund wird innerhalb des Vordergrundtextes gemalt (eingeschnitten).
border-area
-
Der Hintergrund wird innerhalb des Bereichs gemalt, der von der Grenze bemalt wird, wobei
border-width
undborder-style
beachtet werden, aber jede durchborder-color
eingeführte Transparenz ignoriert wird.
Zugänglichkeit
Bei der Verwendung von background-clip: text
überprüfen Sie, dass das Kontrastverhältnis zwischen der Hintergrundfarbe und der Farbe des darüber liegenden Textes hoch genug ist, damit Personen mit Sehbehinderungen den Inhalt der Seite lesen können.
Wenn das Hintergrundbild nicht geladen wird, könnte dies ebenfalls dazu führen, dass der Text unlesbar wird. Fügen Sie eine Rückfall-background-color
hinzu, um dies zu verhindern, und testen Sie ohne das Bild.
Erwägen Sie die Verwendung von Feature-Abfragen mit @supports
, um die Unterstützung von background-clip: text
zu testen und eine zugängliche Alternative zu bieten, falls es nicht unterstützt wird.
Formale Definition
Anfangswert | border-box |
---|---|
Anwendbar auf | alle Elemente. Auch anwendbar auf ::first-letter und ::first-line . |
Vererbt | Nein |
Berechneter Wert | wie angegeben |
Animationstyp | a repeatable list |
Formale Syntax
Beispiele
HTML
<p class="border-box">The background extends behind the border.</p>
<p class="padding-box">
The background extends to the inside edge of the border.
</p>
<p class="content-box">
The background extends only to the edge of the content box.
</p>
<p class="text">The background is clipped to the foreground text.</p>
<p class="border-area">
The background is clipped to the area painted by the border.
</p>
CSS
p {
border: 0.8em darkviolet;
border-style: dotted double;
margin: 1em 0;
padding: 1.4em;
background: linear-gradient(60deg, red, yellow, red, yellow, red);
font: 900 1.2em sans-serif;
text-decoration: underline;
}
.border-box {
background-clip: border-box;
}
.padding-box {
background-clip: padding-box;
}
.content-box {
background-clip: content-box;
}
.text {
background-clip: text;
color: rgb(0 0 0 / 20%);
}
.border-area {
background-clip: border-area;
border-color: transparent;
}
Ergebnis
Spezifikationen
Specification |
---|
CSS Backgrounds and Borders Module Level 3 # background-clip |
CSS Backgrounds Module Level 4 # background-clip |
Browser-Kompatibilität
Siehe auch
- Die
clip-path
Eigenschaft erstellt einen Schnittbereich, der darlegt, welcher Teil eines gesamten Elements angezeigt werden soll. - Hintergrund-Eigenschaften:
background
,background-color
,background-image
,background-origin
- Einführung in das CSS-Box-Modell