Heim > Web-Frontend > CSS-Tutorial > So lösen Sie das Problem des Margenkollapses

So lösen Sie das Problem des Margenkollapses

清浅
Freigeben: 2018-11-20 15:49:13
Original
10376 Leute haben es durchsucht


Dieser Artikel beschreibt das Problem des Margenkollapses und Methoden zur Lösung des Margenkollapses. Er hat einen gewissen Referenzwert und ich hoffe, dass er für das Studium aller hilfreich sein wird.

margin dient zum Festlegen des äußeren Rands des Elements. Normalerweise sollte das übergeordnete Element relativ zum Browser und das untergeordnete Element relativ zum übergeordneten Element positioniert werden Ich stoße oft auf Situationen, in denen Randwerte festgelegt werden, unabhängig davon, wie sie festgelegt werden. Heute werde ich Ihnen die Methode zur Lösung dieses Problems mitteilen.

HTML-Code

<div class="box1">
   <div class="box2"></div>
</div>
Nach dem Login kopieren

CSS-Code

.box1{
	width:200px;
	height:200px;
	background-color:rgb(16,128,214);
	}
.box2{
        width:100px;
	height:100px;
        background-color:rgb(128,227,248);
}
Nach dem Login kopieren

Rendering

Image 12.jpg

Beim Festlegen des Werts für den oberen Rand Änderungen

Beim Festlegen von margin-top:100px für box1 legt box2 auch margin-top:100px fest. Nur das übergeordnete Element ist 100px nach unten relativ zum Browser, aber die Position des untergeordneten Elements relativ zum übergeordneten Element Ist nicht der Fall. Ändern Sie

Image 15.jpg

, aber wenn der für das untergeordnete Element festgelegte Rand oben: 150 Pixel größer ist als die Höhe des übergeordneten Felds, wird das untergeordnete Element nicht mehr positioniert relativ zum übergeordneten Element, aber mit Verschieben des übergeordneten Elements um 150 Pixel nach unten relativ zur Browserpositionierung

Image 14.jpg

Aus dem obigen Inhalt können wir erkennen, was Randkollaps ist

Randreduzierung

Die Randreduzierung tritt auf, wenn das übergeordnete Element relativ zum Browser positioniert ist, das untergeordnete Element jedoch nicht relativ zum übergeordneten Element.

Das untergeordnete Element scheint relativ reduziert zu sein zum übergeordneten Element

Der vertikale Rand der verschachtelten Eltern-Kind-Elemente. Die beiden Elemente werden miteinander kombiniert

Wert

, um das Problem zu lösen. Die Methode zum Zusammenbrechen des Rands

besteht im Wesentlichen darin, den BFC (Blockformatkontext) der Box auszulösen, um die Rendering-Regeln des übergeordneten Elements zu ändern

Methode 1

position:absolute;

Relative Positionierung festlegen

Lösen Sie das Randkollapsproblem, indem Sie dem ein relatives Positionierungsattribut hinzufügen übergeordnetes Element

Image 17.jpg

Methode 2

display:inline-block;

Auf Zeilenblockebenenelement setzen

Image 17.jpg

Methode 3

float:left und float:right;

Verwenden Sie float, um den Stil zu ändern

Image 17.jpg

Methode 4

overflow:hidden

Teilweise ausgeblendete Anzeige der Überlaufbox

Image 18.jpg

Zusammenfassung: das Obige Das war’s für diesen Artikel. Ich hoffe, es hilft allen.



Das obige ist der detaillierte Inhalt vonSo lösen Sie das Problem des Margenkollapses. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage