CSS佈局之div交叉排布與底部對齊--flex實現

来源:http://www.cnblogs.com/yangtoude/archive/2016/11/17/6075494.html
-Advertisement-
Play Games

採用CSS的flex佈局可以很容易的實現特殊佈局,比如垂直居中,div底部對齊等。我遇到了一個交叉佈局的需求,然後用flex佈局很愉快的把它給解決了。 ...


最近在用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>div左右交叉佈局--文字和圖片交叉</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 <div class="C">
27   <div class="row">
28     <div class="col-md-6">
29       <div class="IW">
30         <img class="I" src="../../asset/images/flex/r1.jpg" alt="">
31       </div>
32     </div>
33     <div class="col-md-6">
34       <div class="TW">我是文字,我用到了padding來實現大致居中</div>
35     </div>
36   </div>
37   <div class="row">
38     <div class="col-md-6 col-md-push-6">
39       <div class="IW">
40         <img class="I" src="../../asset/images/flex/r1.jpg" alt="">
41       </div>
42     </div>
43     <div class="col-md-6 col-md-pull-6">
44       <div class="TW">我是文字,我用到了padding來實現大致居中</div>
45     </div>
46   </div>
47   <div class="row">
48     <div class="col-md-6">
49       <div class="IW">
50         <img class="I" src="../../asset/images/flex/r1.jpg" alt="">
51       </div>
52     </div>
53     <div class="col-md-6">
54       <div class="TW">我是文字,我用到了padding來實現大致居中</div>
55     </div>
56   </div>
57 </div>
58   </body>
59 </html>

電腦上效果:

     

手機上效果:

用bootstrap這種方法需要寫多個row(我試著用一個row來實現,但沒成功),另外需要註意的就是,在col-md這層,最好不要再另外添加類(樣式),如果需要控制裡層的元素(上面的例子中是圖片和文字),比如加個padding之類的,可以再加一層div來寫樣式。

第二種方法用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>div左右交叉佈局--文字和圖片交叉</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 <div class="C">
42   <div class="R">
43     <div class="I"><img src="../images/flex/r1.jpg" alt=""></div>
44     <div class="W">我是文字,我使用了flex佈局,我按column在主軸y軸上居中對齊。</div>
45   </div>
46   <div class="R">
47     <div class="I"><img src="../images/flex/r1.jpg" alt=""></div>
48     <div class="W">我是文字,我使用了flex佈局,我按column在主軸y軸上居中對齊。</div>
49   </div>
50   <div class="R">
51     <div class="I"><img src="../images/flex/r1.jpg" alt=""></div>
52     <div class="W">我是文字,我使用了flex佈局,我按column在主軸y軸上居中對齊。</div>
53   </div>
54 </div>
55   </body>
56 </html>

電腦上效果如下:

手機上效果如下:

可以看到,用flex實現要靈活一些, 所有的div都按row排列,其中的關鍵在於讓偶數行反向排列: .R:nth-child(even) { flex-direction: row-reverse; } ,然後在手機上讓其正常排列即可 .R { display: block; width: 100%; } 。

 

我還發現,用flex可以很容易的實現兩個div底部對齊,具體代碼如下:

.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>
<div class="C">
  <div class="A">創新</div>
  <div class="A">實驗基地</div>
</div>

其實就是讓C內的div,以主軸為x(按row排列時,主軸即為x,未指明flex-diretion時,預設為按row排列),排布方向為row,然後讓div都在y軸(交叉軸)上處於底部 align-items: flex-end; 

效果如下:

 

當然,也可以用其他方法來實現。比如,讓C相對定位,讓C內其中的一個div絕對定位,然後通過設置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>
<div class="C">
  <div class="A">創新</div>
  <div class="A">實驗基地</div>
</div>

不過顯然,用flex實現更加簡便。

 

ps: 我這篇博客快寫完時,chrome崩潰了5次,不知道是輸入法的原因,還是chrome自己的原因,反正一輸入字元就自動退出。

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 很常用的一款特效純CSS完成tab實現5種不同切換對應內容效果 實例預覽 下載地址 實例代碼 <div class="main"> <ul class="tabs"> <li> <input type="radio" checked name="tabs" id="tab1"> <label for ...
  • 前言 目前主流的node版本管理工具有兩種,nvm和n。兩者差異挺大的,具體分析可以參考一下淘寶FED團隊的一篇文章: 管理 node 版本,選擇 nvm 還是 n? 總的來說,nvm有點類似於 Python 的 virtualenv 或者 Ruby 的 rvm,每個node版本的模塊都會被安裝在各 ...
  • 手機網頁自適應之rem和viewport。在寫手機網頁時,對於像素的問題會非常困惑,初學者很多時候會因為那麼一個小點的問題解決不了,或者無法理解透徹就放棄了學習。 ...
  • jquery.validation.js 表單驗證 官網地址:http://bassistance.de/jquery-plugins/jquery-plugin-validation jQuery plugin: Validation 使用說明 一導入js庫<script src="../js/j ...
  • https://developer.mozilla.org/en US/docs/Web/JavaScript/Reference/Global_Objects/JSON js數據類型: js Object JSON.stringify(); JSON.parse(); ...
  • Kendo UI是一個強大的框架用於快速HTML5 UI開發。基於最新的HTML5、CSS3和JavaScript標準。 Kendo UI包含了開發現代JavaScript開發所需要的所有一切,包括:強大的數據源,通用的拖拉(Drag-and-Drop)功能,模板,和UI控制項。 今天開始就對項目里使 ...
  • 簡單的來說,就是給每個需要綁定的元素加上$watcher,緩存下oldValue,然後定時遍歷所有的$watcher,比較newValue和oldValue,如果變化了就做更新的操作。 ...
  • HTML5表單在原有表單特性的基礎上增加了一些比較便捷的特性,使得我們實現一些常用的表單的小部件、輸入類型、輸入驗證不再那麼大費周章。上一篇文章提到了HTML5實現的幾種新的輸入類型,現在我們更加詳盡的瞭解HTML5的表單產生的新特性和功能。 1. 輸入類型和輸入屬性 菜鳥教程上給出了HTML5新增 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...