Heim > Web-Frontend > CSS-Tutorial > Warum schlagen abgerundete Ecken mit „overflow: versteckt' in WebKit und Opera fehl und wie kann ich das beheben?

Warum schlagen abgerundete Ecken mit „overflow: versteckt' in WebKit und Opera fehl und wie kann ich das beheben?

Patricia Arquette
Freigeben: 2024-12-19 04:54:09
Original
212 Leute haben es durchsucht

Why Do Rounded Corners with `overflow: hidden` Fail in WebKit and Opera, and How Can I Fix It?

Behebung versteckter Überlaufprobleme mit abgerundeten CSS3-Ecken in WebKit und Opera

Das Maskieren von Inhalten unter abgerundeten Ecken erfordert oft die Verwendung der overflow:hidden-Eigenschaft. Diese Technik kann jedoch in WebKit-basierten Browsern (einschließlich Chrome) und Opera zu Fehlfunktionen führen, wenn das übergeordnete Element relativ oder absolut positioniert ist.

Problem:

Zur Veranschaulichung: Beachten Sie bei diesem Problem den folgenden Code:

#wrapper {
  width: 300px;
  height: 300px;
  border-radius: 100px;
  overflow: hidden;
  position: absolute;
}

#box {
  width: 300px;
  height: 300px;
  background-color: #cde;
}
Nach dem Login kopieren

In diesem Fall ist das #wrapper-Div absolut positioniert und hat abgerundete Ecken. In WebKit-basierten Browsern und Opera läuft der Inhalt des #box div jedoch über die abgerundeten Ecken hinaus.

Lösung: WebKit-CSS-Maske

Eine alternative Lösung zur Lösung dieses Problems besteht darin, eine WebKit-CSS-Maske für das #wrapper-Element zu verwenden. Dabei wird ein Einzelpixel-PNG-Bild als Maske verwendet:

#wrapper {
  width: 300px;
  height: 300px;
  border-radius: 100px;
  overflow: hidden;
  position: absolute;
  /* This fixes the overflow in Chrome/Opera */
  -webkit-mask-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAIAAACQd1PeAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAA5JREFUeNpiYGBgAAgwAAAEAAGbA+oJAAAAAElFTkSuQmCC);
}
Nach dem Login kopieren

Diese Technik verbirgt erfolgreich den Überlauf in WebKit-basierten Browsern und Opera, sodass die abgerundeten Ecken den Inhalt des untergeordneten Elements effektiv maskieren können.

Das obige ist der detaillierte Inhalt vonWarum schlagen abgerundete Ecken mit „overflow: versteckt' in WebKit und Opera fehl und wie kann ich das beheben?. 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