search
HomeWeb Front-endCSS TutorialCSS layout flex implements div cross arrangement and bottom alignment method

When I was writing a page using wordpress recently, the designer came up with a web page layout pattern that I had never encountered before. Its rendering on a computer (resolution greater than 768px) is as follows:

CSS layout flex implements div cross arrangement and bottom alignment method

On mobile phones (resolution is less than or equal to 768px), it is required to be arranged like this:

CSS layout flex implements div cross arrangement and bottom alignment method

I thought of two methods

The first is to use bootstrap's row and col-md together with col-md-push and col-md-pull to achieve . The code is as follows:

 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  class="I lazy" src="/static/imghwm/default1.png" data-src="../../asset/images/flex/r1.jpg" alt="CSS layout flex implements div cross arrangement and bottom alignment method" >31       </p>32     33     <p>34       </p><p>我是文字,我用到了padding来实现大致居中</p>35     36   37   <p>38     </p><p>39       </p><p>40         <img  class="I lazy" src="/static/imghwm/default1.png" data-src="../../asset/images/flex/r1.jpg" alt="CSS layout flex implements div cross arrangement and bottom alignment method" >41       </p>42     43     <p>44       </p><p>我是文字,我用到了padding来实现大致居中</p>45     46   47   <p>48     </p><p>49       </p><p>50         <img  class="I lazy" src="/static/imghwm/default1.png" data-src="../../asset/images/flex/r1.jpg" alt="CSS layout flex implements div cross arrangement and bottom alignment method" >51       </p>52     53     <p>54       </p><p>我是文字,我用到了padding来实现大致居中</p>55     56   57 58   59 

Effect on computer:

CSS layout flex implements div cross arrangement and bottom alignment method

Effect on mobile phone:

CSS layout flex implements div cross arrangement and bottom alignment method

##Use bootstrap method You need to write multiple rows (I tried to use one row to achieve it, but failed). Another thing to note is that in the col-md layer, it is best not to add additional classes (styles) if you need to control the elements in the inner layer. (In the above example, it is pictures and text). For example, if you add padding, you can add a layer of p to write the style.

The second method uses flex-direction: row-reverse in flex layout to implement , the code is as follows:

 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  src="/static/imghwm/default1.png" data-src="../images/flex/r1.jpg" class="lazy" alt="CSS layout flex implements div cross arrangement and bottom alignment method" ></p>44     <p>我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>45   46   <p>47     </p><p><img  src="/static/imghwm/default1.png" data-src="../images/flex/r1.jpg" class="lazy" alt="CSS layout flex implements div cross arrangement and bottom alignment method" ></p>48     <p>我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>49   50   <p>51     </p><p><img  src="/static/imghwm/default1.png" data-src="../images/flex/r1.jpg" class="lazy" alt="CSS layout flex implements div cross arrangement and bottom alignment method" ></p>52     <p>我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>53   54 55   56 

The effect on the computer is as follows:

CSS layout flex implements div cross arrangement and bottom alignment method

The effect on the mobile phone is as follows:

CSS layout flex implements div cross arrangement and bottom alignment method

You can see that it is implemented with flex To be more flexible, all p's are arranged in rows. The key is to arrange the even rows in reverse:

.R:nth-child(even) { flex-direction: row-reverse; }, and then arrange it normally on the mobile phone .R { display: block; width: 100%; }.

I also found that using flex can easily achieve bottom alignment of two ps. The specific code is as follows:

.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>

In fact, let p in C take the main axis as x (when arranged by row, the main axis is x, when flex-diretion is not specified, the default is to arrange by row), the arrangement direction is row, and then let p all be in The y-axis (cross axis) is at the bottom

align-items: flex-end;

The effect is as follows:

CSS layout flex implements div cross arrangement and bottom alignment method

##Of course, other methods can also be used to achieve this. For example, let C be positioned relatively, let one p in C be positioned absolutely, and then set bottom to 0. The code is as follows, and the effect is the same as above.

<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>

But obviously, it is easier to implement with flex.

The above is the detailed content of CSS layout flex implements div cross arrangement and bottom alignment method. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
@keyframes vs CSS Transitions: What is the difference?@keyframes vs CSS Transitions: What is the difference?May 14, 2025 am 12:01 AM

@keyframesandCSSTransitionsdifferincomplexity:@keyframesallowsfordetailedanimationsequences,whileCSSTransitionshandlesimplestatechanges.UseCSSTransitionsforhovereffectslikebuttoncolorchanges,and@keyframesforintricateanimationslikerotatingspinners.

Using Pages CMS for Static Site Content ManagementUsing Pages CMS for Static Site Content ManagementMay 13, 2025 am 09:24 AM

I know, I know: there are a ton of content management system options available, and while I've tested several, none have really been the one, y'know? Weird pricing models, difficult customization, some even end up becoming a whole &

The Ultimate Guide to Linking CSS Files in HTMLThe Ultimate Guide to Linking CSS Files in HTMLMay 13, 2025 am 12:02 AM

Linking CSS files to HTML can be achieved by using elements in part of HTML. 1) Use tags to link local CSS files. 2) Multiple CSS files can be implemented by adding multiple tags. 3) External CSS files use absolute URL links, such as. 4) Ensure the correct use of file paths and CSS file loading order, and optimize performance can use CSS preprocessor to merge files.

CSS Flexbox vs Grid: a comprehensive reviewCSS Flexbox vs Grid: a comprehensive reviewMay 12, 2025 am 12:01 AM

Choosing Flexbox or Grid depends on the layout requirements: 1) Flexbox is suitable for one-dimensional layouts, such as navigation bar; 2) Grid is suitable for two-dimensional layouts, such as magazine layouts. The two can be used in the project to improve the layout effect.

How to Include CSS Files: Methods and Best PracticesHow to Include CSS Files: Methods and Best PracticesMay 11, 2025 am 12:02 AM

The best way to include CSS files is to use tags to introduce external CSS files in the HTML part. 1. Use tags to introduce external CSS files, such as. 2. For small adjustments, inline CSS can be used, but should be used with caution. 3. Large projects can use CSS preprocessors such as Sass or Less to import other CSS files through @import. 4. For performance, CSS files should be merged and CDN should be used, and compressed using tools such as CSSNano.

Flexbox vs Grid: should I learn them both?Flexbox vs Grid: should I learn them both?May 10, 2025 am 12:01 AM

Yes,youshouldlearnbothFlexboxandGrid.1)Flexboxisidealforone-dimensional,flexiblelayoutslikenavigationmenus.2)Gridexcelsintwo-dimensional,complexdesignssuchasmagazinelayouts.3)Combiningbothenhanceslayoutflexibilityandresponsiveness,allowingforstructur

Orbital Mechanics (or How I Optimized a CSS Keyframes Animation)Orbital Mechanics (or How I Optimized a CSS Keyframes Animation)May 09, 2025 am 09:57 AM

What does it look like to refactor your own code? John Rhea picks apart an old CSS animation he wrote and walks through the thought process of optimizing it.

CSS Animations: Is it hard to create them?CSS Animations: Is it hard to create them?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.