Behebung der Ignorierung der maximalen Breite in Firefox und Opera innerhalb von Display: table-cell
Trotz der Angabe der maximalen Breite für Bilder hat Firefox und Opera ignorieren diesen Stil in display:table-cell. Dies kann zu unerwartetem Verhalten führen, wenn versucht wird, die Breite von Bildern in tabellenartigen Strukturen einzuschränken.
Grund für das Ignorieren der maximalen Breite
Gemäß der W3C-Spezifikation Die Eigenschaft max-width gilt nicht für Inline-Elemente. Bilder sind standardmäßig Inline-Elemente. Daher wird innerhalb einer Tabellenzelle (die als Inline-Element fungiert) die maximale Breite nicht berücksichtigt.
Problemumgehung und Einhaltung der W3C-Standards
Eine Problemumgehung besteht darin, den Inhalt zu verschachteln Tabellenzellen-Div innerhalb eines anderen Div, das display: table und table-layout: behoben hat. Durch das Festlegen dieser Eigenschaften im übergeordneten Container respektieren sowohl Firefox als auch Opera die maximale Breitenregel für Bilder in den Tabellenzellen.
Diese Lösung stellt die Einhaltung der W3C-Spezifikation sicher, da sie die standardmäßige Inline-Natur nicht ändert Anzahl der Bilder in der Anzeige: Tabellenzelle. Es fügt einfach eine Tabellenstruktur zum übergeordneten Container hinzu und zwingt die Browser, die inneren Zellen als Tabellenzellen und nicht als Inline-Elemente zu behandeln.
Beispiel
Unten finden Sie ein Beispiel dieser Problemumgehung in Aktion:
<code class="html"><div style="display: table;"> <div style="display: table-cell; padding: 15px; width: 200px;"> <img src="image.png" style="max-width: 100%;" /> <p>Content goes here...</p> </div> </div></code>
Mit dieser Technik können Sie die gewünschte Bildskalierung innerhalb von Tabellenzellen beibehalten und gleichzeitig die browserübergreifende Kompatibilität sicherstellen.
Das obige ist der detaillierte Inhalt vonWarum respektieren Firefox und Opera die maximale Breite von Bildern in der Anzeige: Tabellenzelle nicht?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!