Verstehen des Problems mit dem prozentualen Überlauf der CSS-Rasterlücke
Bei der Verwendung von CSS-Rastern kann die Angabe der Rasterlückeneigenschaft als Prozentsatz manchmal zu unerwarteten Ergebnissen führen Ergebnisse, insbesondere überfüllter Inhalt. In diesem Artikel befassen wir uns mit den Gründen für diesen Überlauf und bieten eine Lösung zu dessen Behebung.
Das Problem: Prozentuale Lücken und Inhaltsgröße
Zunächst Der prozentuale Wert für die Gitterlücke wird relativ zur Höhe des Gitterbehälters berechnet. Dieser Ansatz kann jedoch zu Inkonsistenzen im Verhalten verschiedener Browser führen. Browser berechnen zunächst die Höhe des Rasters anhand seines Inhalts und ignorieren dabei praktisch die prozentuale Lücke. Dadurch füllt der Inhalt den gesamten Rasterraum aus, was zu einem Überlauf außerhalb des Rasters führt.
Beispiel:
Bedenken Sie den folgenden Code:
.grid { display: grid; grid-gap: 50%; background-color: blue; } .grid-1 { background-color: red; }
<div class="grid"> <div class="grid-1"> test </div> <div class="grid-1"> test </div> <div class="grid-1"> test </div> </div>
Lösung: Rasterhöhe anpassen
Um dieses Problem zu beheben, Wir können die Höhe des Gitters explizit anpassen. Ein Ansatz besteht darin, die Eigenschaft height zu verwenden und sicherzustellen, dass sie größer als die Gesamthöhe des Inhalts ist:
.grid { display: grid; grid-gap: 50%; background-color: blue; height: calc(100% + 50%); }
Alternativ können wir die Funktion calc() verwenden, um die Höhe des Rasters basierend auf dem Prozentsatz zu definieren Lücke:
.grid { display: grid; grid-gap: 50%; background-color: blue; height: calc(100% + 25% * 2); // 50% divided by 2 for each gap }
Durch die explizite Definition der Rasterhöhe stellen wir sicher, dass es sowohl den Inhalt als auch die prozentuale Lücke berücksichtigt und so ein Überlaufen verhindert Inhalt.
Das obige ist der detaillierte Inhalt vonWarum läuft mein CSS-Raster über, wenn ich die prozentuale Lücke verwende?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!