Heim >Web-Frontend >CSS-Tutorial >Nutzungsszenarien, Techniken und Vorteile von CSS mit mehreren Hintergründen
【Empfohlenes Tutorial: CSS-Video-Tutorial】
CSS background
ist eine der am häufigsten verwendeten CSS-Eigenschaften. Allerdings wissen nicht alle Entwickler, wie man mehrere Hintergründe verwendet. Dieses Mal ging es darum, verschiedene Hintergrundszenen zu verwenden. In diesem Artikel wird die Eigenschaft „Hintergrundbild“ ausführlich vorgestellt und mit Grafiken kombiniert, um die Verwendung mehrerer Hintergründe und ihre praktischen Vorteile zu erläutern. background
是最常用的CSS属性之一。然而,并不是所有开发人员都知道使用多种背景。这段时间都在关注使用多种背景场景。在本文中,会详细介绍background-image`属性,并结合图形来解释多个背景使用方式以及其实际好处。
如果你还了解 CSS background 属性,可以去先 MDN 查看相关的知识。
CSS background
属性是以下属性的简写:
background-clip, background-color, background-image, background-origin, background-position, background-repeat, background-size 和 background-attachment.
对于本文,将重点介绍background-image
,background-position
和background-size
。 你准备好了吗? 让我们开始吧!
考虑下面的例子:
.element { background: url(cool.jpg) top left/50px 50px no-repeat; }
背景图片位于元素的左上角,大小为50px * 50px
。 了解并记住位置和大小的顺序很重要。
在上图中,background-position
后面是background-size
。它们的顺序是不能调换的,否则无效,如下所示:
.element { /* 警告:无效的CSS */ background: url(cool.jpg) 50px 50px/top left no-repeat; }
元素的定位相对于background-origin
属性设置的定位层。我喜欢background-position
的灵活性,它有多种定位元素的方式:
top
,right
,bottom
,left
,center
)50%
20px
, 2.5rem
top 20px left 10px
坐标系统从左上角开始,默认值为0% 0%
。
值得一提的是,top left
的值与left top
的值相同。 浏览器足够聪明,可以确定其中哪个个用于x
轴,哪个用于y
轴。
.element { background: url(cool.jpg) top left/50px 50px no-repeat; /* 上面与下面相同 */ background: url(cool.jpg) left top/50px 50px no-repeat; }
对于background-size
属性,第一个是width
,第二个是height
。
不必使用两个值,你可以使用一个值,它表示宽度和高度都一样。
现在,我已经了解了CSS background
的工作原理,下面来探讨下如何使用多个背景。
background
background
-Eigenschaft ist die Abkürzung der folgenden Eigenschaften: background-clip, background-color, background-image, background- Ursprung, Hintergrundposition, Hintergrundwiederholung, Hintergrundgröße und Hintergrundanhang.In diesem Artikel konzentrieren wir uns auf
Hintergrundbild
, Hintergrundposition code> und background-size
. Sind Sie bereit? Fangen wir an! Betrachten Sie das folgende Beispiel:
.element { background: url(cool.jpg) top left/50px 50px no-repeat, url(cool.jpg) center/50px 50px no-repeat; }Das Hintergrundbild befindet sich in der oberen linken Ecke des Elements und hat eine Größe von
50px * 50px
. Es ist wichtig, die Reihenfolge von Position und Größe zu verstehen und sich daran zu erinnern.
Im Bild oben,background-position folgt background-size
. Ihre Reihenfolge kann nicht umgetauscht werden, andernfalls ist sie ungültig, wie unten gezeigt:
.hero { min-height: 350px; background: url('table.jpg') center/cover no-repeat, url('konafa.svg') center/50px no-repeat; }
Die Positionierung des Elements ist relativ zu der durch den Hintergrund- eingestellten Positionierung. origin
-Attributebene. Mir gefällt die Flexibilität von background-position
, das mehrere Möglichkeiten zur Positionierung von Elementen bietet:
top
, right, <code>bottom
, left
, center
)
50% code>
20px
, 2.5rem
oben 20px links 10px
Das Koordinatensystem beginnt in der oberen linken Ecke und der Standardwert ist 0% 0%
.
top left
derselbe ist wie der Wert von left top
. Der Browser ist intelligent genug, um zu bestimmen, welche davon für die x
-Achse und welche für die y
-Achse gelten. .hero { background: linear-gradient(rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0.15)), url("landscape.jpg") center/cover; }
background-size
ist das erste Attribut width
und das zweite Attribut height
.
Es müssen keine zwei Werte verwendet werden , Sie können einen Wert verwenden, der bedeutet, dass Breite und Höhe gleich sind.
🎜🎜🎜Jetzt verstehe ich, wie CSSbackground
funktioniert. Lassen Sie uns besprechen, wie Sie mehrere Hintergründe verwenden. 🎜background
kann eine oder mehrere durch Kommas getrennte Ebenen haben. Wenn mehrere Hintergründe die gleiche Größe haben, deckt einer den anderen ab. 🎜.hero { background: linear-gradient(135deg, rgba(177, 234, 77, 0.25), rgba(69, 149, 34, 0.25), url("landscape.jpg") center/cover; }🎜🎜🎜🎜Im Bild oben haben wir zwei Hintergrundebenen. Jeder Standort ist anders. Dies ist die grundlegende Verwendung mehrerer Hintergründe. Schauen wir uns ein fortgeschritteneres Beispiel an. 🎜🎜Platzierungsreihenfolge🎜🎜Wenn mehrere Hintergründe platziert werden und ein Hintergrund die gesamte Breite und Höhe seines übergeordneten Hintergrunds einnimmt, kann die Platzierungsreihenfolge etwas chaotisch sein: 🎜
:root { --case: linear-gradient(#222, #222); --case-size: 152px 103px; --display: linear-gradient(#fff, #fff); --display-size: 137px 87px; --reflection: linear-gradient(205deg, #fff, rgba(255, 255, 255, 0)); --reflection-size: 78px 78px; --body: linear-gradient(#888, #888); --body-size: 182px 9px; --circle: radial-gradient(9px 9px at 5px 5.5px, #888 50%, transparent 50%); --circle-size: 10px 10px; }🎜🎜🎜🎜Wir haben einen Teller und einen Ein Bild eines Tisches. Welcher wird Ihrer Meinung nach oben stehen? 🎜🎜Die Antwort ist 🎜Tabelle🎜. In CSS kann der erste Hintergrund auf dem zweiten Hintergrund platziert werden, der zweite Hintergrund kann auf dem dritten Hintergrund platziert werden und so weiter. Durch Ersetzen der Reihenfolge der Hintergründe können die erwarteten Ergebnisse erzielt werden. 🎜🎜🎜🎜🎜Anwendungsfälle und Beispiele🎜🎜Maskenebene🎜🎜Oft müssen wir möglicherweise eine Maskenebene über einem bestimmten Abschnitt platzieren, um den Text leichter lesbar zu machen. Dies lässt sich ganz einfach durch das Stapeln zweier Hintergründe bewerkstelligen. 🎜
:root { --case: linear-gradient(#222, #222); --case-size: 152px 103px; --case-pos: center 0; --display: linear-gradient(#fff, #fff); --display-size: 137px 87px; --display-pos: center 6px; --reflection: linear-gradient(205deg, #fff, rgba(255, 255, 255, 0)); --reflection-size: 78px 78px; --reflection-pos: top right; --body: linear-gradient(#888, #888); --body-size: 182px 9px; --body-pos: center bottom; --circle: radial-gradient(9px 9px at 5px 5.5px, #888 50%, transparent 50%); --circle-size: 10px 10px; --circle-left-pos: left bottom; --circle-right-pos: right bottom; } .cool { width: 190px; height: 112px; background-image: var(--reflection), var(--display), var(--case), var(--circle), var(--circle), var(--body); background-size: var(--reflection-size), var(--display-size), var(--case-size), var(--circle-size), var(--circle-size), var(--body-size); background-position: var(--reflection-pos), var(--display-pos), var(--case-pos), var(--circle-left-pos), var(--circle-right-pos), var(--body-pos); background-repeat: no-repeat; /*outline: solid 1px;*/ }🎜🎜🎜🎜Das Gute daran ist, dass wir mit der gleichen Methode wie oben Farbe auf Elemente anwenden können. Bedenken Sie Folgendes: 🎜
.hero { background: linear-gradient(135deg, rgba(177, 234, 77, 0.25), rgba(69, 149, 34, 0.25), url("landscape.jpg") center/cover; }
用 CSS 绘图
使用 CSS 渐变绘制的可能性是无限的。 你可以使用linear-gradient
或radial-gradient
等。接着,我们来看看如何使用它两兄弟绘制笔记本电脑。
拆解笔记本电脑,看看我们需要使用什么渐变。
拆解笔记本电脑的时,更容易考虑如何使用多个 CSS 背景来实现它。
接下来是图纸。 首先是将每个渐变定义为CSS变量及其大小。 我喜欢使用CSS变量,因为它可以减少代码的复杂性,使代码更简洁,更易于阅读。
:root { --case: linear-gradient(#222, #222); --case-size: 152px 103px; --display: linear-gradient(#fff, #fff); --display-size: 137px 87px; --reflection: linear-gradient(205deg, #fff, rgba(255, 255, 255, 0)); --reflection-size: 78px 78px; --body: linear-gradient(#888, #888); --body-size: 182px 9px; --circle: radial-gradient(9px 9px at 5px 5.5px, #888 50%, transparent 50%); --circle-size: 10px 10px; }
现在我们定义了渐变及其大小,下一步是放置它们。 考虑下图,以获得更好的视觉解释。
显示影像
如前所述,应该首先定义需要在顶部的元素。 在我们的情况下,显示影像应该是第一个渐变。
显示 LCD
显示屏位于x
轴中心,距y轴6px
。
显示 外壳
外壳位于显示器下方,位于x轴的中心,距y轴的位置为0px
。
主体
这是图形中最有趣的组件。 首先,主体是一个矩形,每个侧面(左侧和右侧)有两个圆圈。
最终结果
:root { --case: linear-gradient(#222, #222); --case-size: 152px 103px; --case-pos: center 0; --display: linear-gradient(#fff, #fff); --display-size: 137px 87px; --display-pos: center 6px; --reflection: linear-gradient(205deg, #fff, rgba(255, 255, 255, 0)); --reflection-size: 78px 78px; --reflection-pos: top right; --body: linear-gradient(#888, #888); --body-size: 182px 9px; --body-pos: center bottom; --circle: radial-gradient(9px 9px at 5px 5.5px, #888 50%, transparent 50%); --circle-size: 10px 10px; --circle-left-pos: left bottom; --circle-right-pos: right bottom; } .cool { width: 190px; height: 112px; background-image: var(--reflection), var(--display), var(--case), var(--circle), var(--circle), var(--body); background-size: var(--reflection-size), var(--display-size), var(--case-size), var(--circle-size), var(--circle-size), var(--body-size); background-position: var(--reflection-pos), var(--display-pos), var(--case-pos), var(--circle-left-pos), var(--circle-right-pos), var(--body-pos); background-repeat: no-repeat; /*outline: solid 1px;*/ }
混合使用多个背景时会令人兴奋。 考虑一下您在CSS中有一个背景图像,并且想要将其变成黑白图像。
.hero { background: linear-gradient(#000, #000), url("landscape.jpg") center/cover; background-blend-mode: color; }
更多编程相关知识,请访问:编程视频!!
Das obige ist der detaillierte Inhalt vonNutzungsszenarien, Techniken und Vorteile von CSS mit mehreren Hintergründen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!