Heim > Web-Frontend > CSS-Tutorial > Warum funktioniert „overflow:hidden' nicht bei fest positionierten übergeordneten/untergeordneten Elementen in CSS?

Warum funktioniert „overflow:hidden' nicht bei fest positionierten übergeordneten/untergeordneten Elementen in CSS?

Barbara Streisand
Freigeben: 2024-12-05 12:17:11
Original
467 Leute haben es durchsucht

Why Doesn't `overflow: hidden` Work on Fixed Positioned Parent/Child Elements in CSS?

Overflow:hidden Unwirksam bei positionierten übergeordneten/untergeordneten Elementen: Ein Problem oder beabsichtigt?

In CSS verbirgt die Eigenschaft overflow:hidden Inhalt, der über die Grenzen seines Containerelements hinausgeht. Es kommt jedoch zu unerwartetem Verhalten, wenn versucht wird, diese Eigenschaft für ein als fest positioniertes Element mit festen untergeordneten Elementen zu verwenden. Die erwartete Überlaufkürzung tritt nicht auf.

Beispiel:

.parent {
  position: fixed;
  overflow: hidden;
  width: 300px;
  height: 300px;
  background: #555;
}
.children {
  position: fixed;
  top: 200px;
  left: 200px;
  width: 150px;
  height: 150px;
  background: #333;
}
Nach dem Login kopieren

Erklärung:

Dieses Problem entsteht durch a Einschränkung in CSS: overflow:hidden verbirgt nur effektiv Inhalte innerhalb des Flusses eines Elements. Positionierte Elemente werden wie bei position:fixed aus dem normalen Fluss entfernt und nehmen nicht an der Überlaufbehandlung teil.

Alternative Lösung: CSS-Clip-Eigenschaft

Zu Um das gewünschte Überlauf-Clipping-Verhalten bei positionierten Elementen zu erreichen, sollten Sie die Verwendung der Clip-Eigenschaft in Betracht ziehen. Damit können Sie rechteckige Bereiche innerhalb eines Elements definieren, die sichtbar oder ausgeblendet sind.

Beispiel:

.parent {
  position: fixed;
  clip: rect(0px, 300px, 300px, 0px);
  width: 300px;
  height: 300px;
  background: #555;
}
Nach dem Login kopieren

Hinweise:

  • Die Position des übergeordneten Elements darf nicht statisch oder relativ sein.
  • Rechteckige Koordinaten werden nicht unterstützt Prozentsätze (außer „auto“).
  • Untergeordnete Elemente können in bestimmten Browsern wie IE und Chrome Positionierungsbeschränkungen haben.

Zusätzliche Überlegungen:

  • Backface-visibility hinzufügen: versteckt; um die Handhabung der Positionierung untergeordneter Elemente und CSS3-Transformationen zu verbessern.
  • Mobile Browser und ältere Versionen unterstützen die Clip-Eigenschaft möglicherweise nur eingeschränkt.

Das obige ist der detaillierte Inhalt vonWarum funktioniert „overflow:hidden' nicht bei fest positionierten übergeordneten/untergeordneten Elementen in CSS?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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