mask-clip CSS property
Baseline
2023
*
Neu verfügbar
Seit December 2023 funktioniert diese Funktion auf aktuellen Geräten und in aktuellen Browserversionen. Auf älteren Geräten oder in älteren Browsern funktioniert sie möglicherweise nicht.
* Einige Teile dieser Funktion werden möglicherweise unterschiedlich gut unterstützt.
Die mask-clip CSS Eigenschaft bestimmt den Bereich, der von einer Maske betroffen ist. Der bemalte Inhalt eines Elements muss auf diesen Bereich beschränkt sein.
Syntax
/* <coord-box> values */
mask-clip: content-box;
mask-clip: padding-box;
mask-clip: border-box;
mask-clip: fill-box;
mask-clip: stroke-box;
mask-clip: view-box;
/* Keyword values */
mask-clip: no-clip;
/* Multiple values */
mask-clip: padding-box, no-clip;
mask-clip: view-box, fill-box, border-box;
/* Global values */
mask-clip: inherit;
mask-clip: initial;
mask-clip: revert;
mask-clip: revert-layer;
mask-clip: unset;
Werte
Die Eigenschaft akzeptiert eine durch Kommas getrennte Liste von Schlüsselwortwerten. Jeder Wert ist ein <coord-box> oder no-clip:
content-box-
Der bemalte Inhalt wird auf die Inhaltsbox (content box) zugeschnitten.
padding-box-
Der bemalte Inhalt wird auf die Padding-Box zugeschnitten.
border-box-
Der bemalte Inhalt wird auf die Rahmenbox (border box) zugeschnitten.
fill-box-
Der bemalte Inhalt wird auf die Objektbegrenzungsbox zugeschnitten.
stroke-box-
Der bemalte Inhalt wird auf die Umrandungsbox (stroke bounding box) zugeschnitten.
view-box-
Verwendet die nächstgelegene SVG-Ansichtsportbox als Referenzbox. Wenn ein
viewBox-Attribut für das Element, das den SVG-Ansichtsport erstellt, angegeben ist, wird die Referenzbox am Ursprung des Koordinatensystems positioniert, das durch dasviewBox-Attribut etabliert wird, und die Dimension der Referenzbox wird auf die Breiten- und Höhenwerte desviewBox-Attributs festgelegt. no-clip-
Der bemalte Inhalt wird nicht zugeschnitten.
border-
Dieses Schlüsselwort verhält sich wie
border-box. padding-
Dieses Schlüsselwort verhält sich wie
padding-box. content-
Dieses Schlüsselwort verhält sich wie
content-box. text-
Dieses Schlüsselwort schneidet das Maskenbild auf den Text des Elements zu.
Beschreibung
Die mask-clip-Eigenschaft definiert den Bereich des Elements, der von der angewendeten Maske betroffen ist.
Für Maskenebenenbilder, die keine SVG <mask>-Elemente referenzieren, definiert die mask-clip-Eigenschaft den Maskenmalbereich oder den Bereich, der von der Maske betroffen ist. Der bemalte Inhalt des Elements wird auf diesen Bereich beschränkt.
Die mask-clip-Eigenschaft hat keinen Einfluss auf ein Maskenebenenbild, das ein <mask>-Element referenziert. Die <mask>-Elemente x, y, width, height, und maskUnits Attribute bestimmen den Maskenmalbereich, wenn die Quelle des mask-image ein <mask> ist.
Ein Element kann mehrere Maskenebenen angewendet haben. Die Anzahl der Ebenen wird durch die Anzahl der durch Kommas getrennten Werte im mask-image-Eigenschaftswert bestimmt (auch wenn ein Wert none ist). Jeder mask-clip-Wert in der Liste der kommagetrennten Werte wird mit den mask-image-Werten verglichen, in der Reihenfolge. Wenn die Anzahl der Werte in den beiden Eigenschaften unterschiedlich ist, werden alle überzähligen Werte von mask-clip nicht verwendet, oder, wenn mask-clip weniger Werte hat als mask-image, werden die mask-clip-Werte wiederholt.
Formale Definition
| Anfangswert | border-box |
|---|---|
| Anwendbar auf | alle Elemente; In SVG gilt betrifft dies Containerelemente mit Ausnahme des <defs> Elements und allen Grafikelementen |
| Vererbt | Nein |
| Berechneter Wert | wie angegeben |
| Animationstyp | diskret |
Formale Syntax
mask-clip =
[ <coord-box> | no-clip ]#
<coord-box> =
<paint-box> |
view-box
<paint-box> =
<visual-box> |
fill-box |
stroke-box
<visual-box> =
content-box |
padding-box |
border-box
Beispiele
>Maskierung auf die Rahmenbox zuschneiden
Dieses Beispiel demonstriert drei mask-clip-Werte.
HTML
Wir fügen drei Elemente ein, jedes mit einem anderen <coord-box>-Wert als Klassenname.
<div class="border-box"></div>
<div class="padding-box"></div>
<div class="content-box"></div>
CSS
Das CSS definiert das Element mit einem Hintergrund, Rahmen, Padding und Margin und einem Maskenbild, wobei jedes <div> eine andere <coord-box> hat. Wir haben Inhalt mit dem Namen der Klasse generiert und diesen Text um 10px nach oben verschoben, um zu verhindern, dass er aus der Sicht maskiert wird.
div {
width: 100px;
height: 100px;
background-color: #8cffa0;
margin: 10px;
border: 20px solid #8ca0ff;
padding: 20px;
mask-image: url("https://mdn.github.io/shared-assets/images/examples/mdn.svg");
mask-size: 100% 100%;
}
.content-box {
mask-clip: content-box;
}
.border-box {
mask-clip: border-box;
}
.padding-box {
mask-clip: padding-box;
}
div::before {
content: attr(class);
position: relative;
top: -10px;
}
Ergebnisse
Spezifikationen
| Spezifikation |
|---|
| CSS Masking Module Level 1> # the-mask-clip> |