Heim >Web-Frontend >CSS-Tutorial >CSS-Layout-Flex implementiert die div-Kreuzanordnung und die untere Ausrichtungsmethode
Als ich kürzlich eine Seite in WordPress schrieb, entwickelte der Designer ein Webseiten-Layoutmuster, das ich noch nie zuvor gesehen hatte. Das Rendering auf einem Computer (Auflösung größer als 768 Pixel) ist wie folgt:
Auf Mobiltelefonen (Auflösung kleiner oder gleich 768 Pixel) muss es wie folgt angeordnet sein:
Ich dachte von zwei Methoden
Die erste Methode besteht darin, Bootstraps row und col-md zusammen mit col-md-push und col-md-pull zu verwenden, um zu implementieren. Der Code lautet wie folgt:
1 nbsp;html> 2 3 4 <meta> 5 <meta> 6 <link> 7 <title>p左右交叉布局--文字和图片交叉</title> 8 9 10 <style>11 .C {12 margin: auto;13 padding: 30px 20px 40px;14 max-width: 600px;15 }16 .I {17 width: 100%;18 }19 .IW, .TW {20 border: 1px solid rgba(0, 0, 0, 0.3);;21 }22 .TW {23 padding: 25%;24 }25 </style>26 <p>27 </p><p>28 </p><p>29 </p><p>30 <img alt="CSS-Layout-Flex implementiert die div-Kreuzanordnung und die untere Ausrichtungsmethode" >31 </p>32 33 <p>34 </p><p>我是文字,我用到了padding来实现大致居中</p>35 36 37 <p>38 </p><p>39 </p><p>40 <img alt="CSS-Layout-Flex implementiert die div-Kreuzanordnung und die untere Ausrichtungsmethode" >41 </p>42 43 <p>44 </p><p>我是文字,我用到了padding来实现大致居中</p>45 46 47 <p>48 </p><p>49 </p><p>50 <img alt="CSS-Layout-Flex implementiert die div-Kreuzanordnung und die untere Ausrichtungsmethode" >51 </p>52 53 <p>54 </p><p>我是文字,我用到了padding来实现大致居中</p>55 56 57 58 59
Die Wirkung auf dem Computer:
Die Wirkung auf dem Mobiltelefon:
Verwenden Sie dafür Bootstrap. Diese Methode erfordert das Schreiben mehrerer Zeilen (ich habe versucht, eine Zeile zu verwenden, um dies zu erreichen, aber es ist fehlgeschlagen. Eine andere Sache, die zu beachten ist, ist, dass es in der col-md-Ebene so ist Es ist am besten, keine zusätzlichen Klassen (Stile) hinzuzufügen. Wenn Sie die Elemente der inneren Ebene (Bilder und Text im obigen Beispiel) steuern müssen, z. B. das Hinzufügen von Auffüllungen usw., können Sie eine Ebene von p hinzufügen, um Stile zu schreiben.
Die zweite Methode verwendet Flex-Direction: Row-Reverse im Flex-Layout, um zu implementieren. Der Code lautet wie folgt:
1 nbsp;html> 2 3 4 <meta> 5 <meta> 6 <title>p左右交叉布局--文字和图片交叉</title> 7 8 9 <style>10 .C {11 margin: auto;12 padding: 30px 20px 40px;13 max-width: 600px;14 }15 .R {16 display: block;17 width: 100%;18 }19 @media only screen and (min-width: 768px) {20 .R {21 display: flex;22 width: 100%;23 }24 }25 .R:nth-child(even) {26 flex-direction: row-reverse;27 }28 .I, .W {29 width: 50%;30 }31 .I img {32 width: 100%;33 }34 .W {35 display: flex;36 flex-direction: column;37 font-size: 16px;38 justify-content: center;39 }40 </style>41 <p>42 </p><p>43 </p><p><img alt="CSS-Layout-Flex implementiert die div-Kreuzanordnung und die untere Ausrichtungsmethode" ></p>44 <p>我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>45 46 <p>47 </p><p><img alt="CSS-Layout-Flex implementiert die div-Kreuzanordnung und die untere Ausrichtungsmethode" ></p>48 <p>我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>49 50 <p>51 </p><p><img alt="CSS-Layout-Flex implementiert die div-Kreuzanordnung und die untere Ausrichtungsmethode" ></p>52 <p>我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>53 54 55 56
Die Wirkung auf dem Computer ist wie folgt:
Die Wirkung auf dem Mobiltelefon ist wie folgt:
Sie können es mit sehen. Die Flex-Implementierung sollte flexibler sein. Der Schlüssel besteht darin, die geraden Zeilen in umgekehrter Reihenfolge anzuordnen: .R:nth-child(even ) { flex-direction: row-reverse } und dann normal auf dem Telefon anordnen .R { display: block; width: 100%;
Ich habe auch festgestellt, dass mit Flex leicht eine untere Ausrichtung von zwei ps erreicht werden kann. Der spezifische Code lautet wie folgt:.C { display: flex; align-items: flex-end; } .A { background: rgba(255, 0, 0, 0.1); } .A:nth-child(odd) { background: #1a88ea; color: white; font-size: 30px; padding: 10px 15px; }<p> </p><p>创新</p> <p>实验基地</p>Tatsächlich soll p in C die Hauptachse als x annehmen (bei der Anordnung nach Reihe ist die Hauptachse x, wenn die Flexrichtung nicht angegeben ist, wird standardmäßig nach Reihe angeordnet), die Anordnungsrichtung ist Zeile, und dann sei p Sie befinden sich alle unten auf der y-Achse (Querachse)
align-items: flex-end;
Der Effekt ist wie folgt: Selbstverständlich sind auch andere Methoden anwendbar. Lassen Sie beispielsweise C relativ positionieren, lassen Sie ein p in C absolut positionieren und setzen Sie dann unten den Wert 0. Der Code lautet wie folgt und der Effekt ist der gleiche wie oben.<style>.C { position: relative;}.A { display: inline-block; background: rgba(255, 0, 0, 0.1);}.A:nth-child(odd) { background: #1a88ea; color: white; font-size: 30px; padding: 10px 15px;}.A:nth-child(even) { bottom: 0; position: absolute;}</style><p> </p><p>创新</p> <p>实验基地</p>Aber offensichtlich ist es mit Flex einfacher umzusetzen.
Das obige ist der detaillierte Inhalt vonCSS-Layout-Flex implementiert die div-Kreuzanordnung und die untere Ausrichtungsmethode. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!