Textumbruch und Breitensteuerung in CSS
In CSS bestimmen die Eigenschaften width und max-width die Breite eines Elements. Wenn der Inhalt eines Elements in mehrere Zeilen umgebrochen wird, entsteht eine Diskrepanz im Verhalten dieser Eigenschaften.
Erwartetes Verhalten:
Basierend auf dem bereitgestellten CSS:
#tooltip { position: absolute; width: auto; min-width: 50px; max-width: 250px; padding: 10px; background-color: #eee; border: 1px solid #aaa; }
Man könnte erwarten, dass sich die Breite des Tooltips an seinen Inhalt anpasst und innerhalb des angegebenen Bereichs schrumpft oder wächst Grenzen.
Tatsächliches Verhalten:
Wenn der Inhalt jedoch in die nächste Zeile umbricht, überschreibt die Eigenschaft „max-width“ die Eigenschaft „width“, was zu einer Tooltip-Breite von 250 Pixeln führt . Dies erzeugt den Anschein einer übermäßigen Auffüllung, wenn das letzte Wort in einer Zeile relativ lang ist.
Grund für das Verhalten:
Ein Browser versucht, Inhalte inline anzuzeigen, bis er erreicht ist erreicht die maximal zulässige Breite, in diesem Fall 250 Pixel. Wenn der Inhalt die maximale Breite nicht erreicht, ermöglicht die Regel „width: auto“, dass der Tooltip verkleinert wird, um ihn an den Inhalt anzupassen.
Sobald der Inhalt jedoch umbrochen wird, wird die Breite des Tooltips auf 250 Pixel festgelegt, wie durch max -Breite. Dies liegt daran, dass der Textumbruch keine Neuberechnung der Breite des Elements auslöst. Die Breite des Tooltips bleibt bei 250 Pixeln, unabhängig von der Inhaltsbreite nach dem Umbrechen.
Fazit:
Dieses Verhalten liegt in der Art und Weise, wie Browser mit dem Umbrechen von Text umgehen, und ist nicht so kann leicht angepasst werden. Daher muss man sich dieses potenziellen ästhetischen Problems bewusst sein, wenn man mit Elementen mit eingeschränkter Breite arbeitet, die ihren Inhalt möglicherweise umschließen.
Das obige ist der detaillierte Inhalt vonWie interagieren „width' und „max-width' mit dem Textumbruch in CSS?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!