您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

CSS布局flex实现div交叉排布与底部对齐方法

2025/11/26 12:13:23发布22次查看
最近在用wordpress写页面时,设计师给出了一种网页排布图样,之前从未遇到过,其在电脑上(分辨率大于768px)的效果图如下:
而在手机(分辨率小于等于768px)上要求这样排列:
我想到了两种方法
第一种是用bootstrap的row、col-md配合col-md-push、col-md-pull来实现,代码如下:
1 <!doctype html> 2 <html> 3   <head> 4     <meta charset="utf-8"> 5     <meta name="viewport" content="width=device-width, initial-scale=1"> 6     <link rel="stylesheet" href="../../vendor/bootstrap-3.3.7-dist/css/bootstrap.min.css" media="screen" title="no title"> 7     <title>p左右交叉布局--文字和图片交叉</title> 8   </head> 9   <body>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 class="c">27   <p class="row">28     <p class="col-md-6">29       <p class="iw">30         <img class="i" src="../../asset/images/flex/r1.jpg" alt="">31       </p>32     </p>33     <p class="col-md-6">34       <p class="tw">我是文字,我用到了padding来实现大致居中</p>35     </p>36   </p>37   <p class="row">38     <p class="col-md-6 col-md-push-6">39       <p class="iw">40         <img class="i" src="../../asset/images/flex/r1.jpg" alt="">41       </p>42     </p>43     <p class="col-md-6 col-md-pull-6">44       <p class="tw">我是文字,我用到了padding来实现大致居中</p>45     </p>46   </p>47   <p class="row">48     <p class="col-md-6">49       <p class="iw">50         <img class="i" src="../../asset/images/flex/r1.jpg" alt="">51       </p>52     </p>53     <p class="col-md-6">54       <p class="tw">我是文字,我用到了padding来实现大致居中</p>55     </p>56   </p>57 </p>58   </body>59 </html>
电脑上效果:
手机上效果:
用bootstrap这种方法需要写多个row(我试着用一个row来实现,但没成功),另外需要注意的就是,在col-md这层,最好不要再另外添加类(样式),如果需要控制里层的元素(上面的例子中是图片和文字),比如加个padding之类的,可以再加一层p来写样式。
第二种方法用flex布局中的flex-direction: row-reverse来实现,代码如下:
1 <!doctype html> 2 <html> 3   <head> 4     <meta charset="utf-8"> 5     <meta name="viewport" content="width=device-width, initial-scale=1"> 6     <title>p左右交叉布局--文字和图片交叉</title> 7   </head> 8   <body> 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 class="c">42   <p class="r">43     <p class="i"><img src="../images/flex/r1.jpg" alt=""></p>44     <p class="w">我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>45   </p>46   <p class="r">47     <p class="i"><img src="../images/flex/r1.jpg" alt=""></p>48     <p class="w">我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>49   </p>50   <p class="r">51     <p class="i"><img src="../images/flex/r1.jpg" alt=""></p>52     <p class="w">我是文字,我使用了flex布局,我按column在主轴y轴上居中对齐。</p>53   </p>54 </p>55   </body>56 </html>
电脑上效果如下:
手机上效果如下:
可以看到,用flex实现要灵活一些, 所有的p都按row排列,其中的关键在于让偶数行反向排列: .r:nth-child(even) { flex-direction: row-reverse; } ,然后在手机上让其正常排列即可 .r { display: block; width: 100%; } 。
我还发现,用flex可以很容易的实现两个p底部对齐,具体代码如下:
.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; }</style><p class="c">   <p class="a">创新</p>   <p class="a">实验基地</p></p>
其实就是让c内的p,以主轴为x(按row排列时,主轴即为x,未指明flex-diretion时,默认为按row排列),排布方向为row,然后让p都在y轴(交叉轴)上处于底部 align-items: flex-end; 
效果如下:
当然,也可以用其他方法来实现。比如,让c相对定位,让c内其中的一个p绝对定位,然后通过设置bottom为0即可,代码如下,效果同上。
<style media="screen">.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 class="c">   <p class="a">创新</p>   <p class="a">实验基地</p></p>
不过显然,用flex实现更加简便。
以上就是css布局flex实现div交叉排布与底部对齐方法的详细内容。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product