Flex-Artikel: Blockebene oder Flex-Ebene?
Flex-Artikel sind ein grundlegender Bestandteil des flexiblen Box-Layouts. Es stellt sich die Frage, ob sie zur Block-Level- oder Flex-Level-Elementkategorie gehören.
Flex-Level-Bezeichnung
Gemäß CSS Flexible Box Layout Module Level 1 sind Flex-Items gelten als Flex-Level-Elemente. Dies bedeutet, dass sie im Flex-Formatierungskontext ihres Containers und nicht in einem Blockformatierungskontext vorhanden sind.
Blockierter Anzeigewert
In der CSS-Spezifikation heißt es jedoch auch, dass die Der Anzeigewert eines Flex-Elements ist „blockiert“. Dies bedeutet, dass, wenn ein Anzeigewert auf Inline-Ebene für ein untergeordnetes Element innerhalb eines Flex-Containers angegeben wird, dieser in sein Äquivalent auf Blockebene konvertiert wird.
Abgleich der Diskrepanz
Um den scheinbaren Widerspruch aufzulösen, ist es wichtig, die Rolle der Anzeigeeigenschaft zu verstehen. Jedes Element verfügt über einen Anzeigewert, der angibt, wie es sich in seinem Formatierungskontext verhält.
Bei Flex-Elementen ist ihr Standardanzeigewert block. Das bedeutet, dass sie von innen, wo sich untergeordnete Elemente befinden, ein Verhalten auf Blockebene zeigen. Von außen betrachtet werden sie jedoch im Kontext ihres Flex-Containers als Flex-Level-Elemente betrachtet, die am Flex-basierten Layout teilnehmen.
Eine doppelte Perspektive
Stellen Sie sich zwei getrennte Welten vor: die Innenwelt und die Außenwelt. Innerhalb eines Flex-Elements wird es von Elementen als Element auf Blockebene wahrgenommen. Innerhalb des Flex-Containers werden die Flex-Elemente selbst als Flex-Level-Elemente betrachtet.
Auswirkungen der Inline-Änderung
Das Festlegen eines Inline-Anzeigewerts für ein Flex-Element ändert dessen wahrgenommene Natur von innen. Der Inline-Aspekt wird entfernt und das Flex-Element erscheint seinen untergeordneten Elementen als Block, Raster, Tabelle oder Flex-Container.
Fazit
Flex-Elemente sind von Natur aus vorhanden Flex-Level-Elemente, sie können jedoch durch Angabe eines Inline-Anzeigewerts „blockiert“ werden. Dadurch können sie das Verhalten ihrer untergeordneten Elemente steuern und gleichzeitig am flexiblen Layout ihres Containers teilnehmen.
Das obige ist der detaillierte Inhalt vonSind Flex-Elemente Block-Level- oder Flex-Level-Elemente?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!