CSS實例詳解:Flex佈局

来源:https://www.cnblogs.com/qcloud1001/archive/2018/12/17/10133027.html
-Advertisement-
Play Games

本文由雲+社區發表 本文將通過三個簡單的實例,實際應用上篇文章的基礎理論知識,展示下Flex佈局是如何解決CSS佈局問題。 一.垂直居中 這裡同時用非flex佈局和flex佈局兩種方式來實現,可以對比兩種實現方式的差異。 1.1用margin實現垂直居中 實現方式: 父元素採用相對定位,子元素採用絕 ...


本文由雲+社區發表

本文將通過三個簡單的實例,實際應用上篇文章的基礎理論知識,展示下Flex佈局是如何解決CSS佈局問題。

一.垂直居中

這裡同時用非flex佈局和flex佈局兩種方式來實現,可以對比兩種實現方式的差異。

1.1用margin實現垂直居中

實現方式:

父元素採用相對定位,子元素採用絕對定位,先將元素的定點定位到父元素的中心,再使用margin負值法,即子元素自身寬度、高度的一半,將其拉回到父元素的中心。

實現效果:

img

附上完整代碼:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>垂直居中--normal</title>
    <style type="text/css">
        body {
            margin: 0;
            padding: 0;
        }

        .container {
            width: 500px;
            height: 300px;
            margin: 80px;
            border: 1px solid blue;

            position: relative;
        }

        .item {
            width: 300px;
            height: 200px;
            border: 1px solid red;

            position: absolute;
            left: 50%;
            top: 50%;
            margin-left: -150px;
            margin-top: -100px;

        }
    </style>
</head>

<body>
    <div class="container">
        <div class="item"></div>
    </div>
</body>

</html>

1.2用flex實現垂直居中

實現方式:

父元素啟用flex佈局(display:flex),同時設置主軸上居中對齊(justify-content:center)、交叉軸上居中對齊(align-items:center)。子元素不需要額外設置樣式。

實現效果:同上

附上完整代碼:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>垂直居中--flex</title>
    <style type="text/css">
        body {
            margin: 0;
            padding: 0;
        }
        .container{
            width:500px;
            height:300px;
            margin:80px;
            border:1px solid blue;

            display:flex;
            justify-content: center;
            align-items: center;
        }
        .item{
            width:300px;
            height:200px;
            border:1px solid red;
        }
    </style>
</head>

<body>
    <div class="container">
        <div class="item"></div>
    </div>
</body>
</html>

二.聖杯佈局

2.1 普通方式實現聖杯佈局

在我之前的文章聖杯佈局與雙飛翼佈局中詳細介紹過如何實現一個聖杯佈局:

(1)中間的三欄佈局,這裡採用margin負值法:兩邊兩欄寬度固定,中間欄寬度自適應,左欄、右欄、中間欄向左浮動,左欄的margin-left設為-100%,中間欄的width設為100%,右欄的margin-left設為-右欄寬度。

(2)給container設置padding-left和padding-right屬性,值分別為左欄、右欄的寬度;

(3)將左右兩欄設置為相對定位,同時左欄的left值設為-左欄寬度,右欄的right設為-右欄寬度。

實現效果:

img

實現代碼:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>聖杯佈局</title>
    <style type="text/css">
        body {
            margin: 0;
            padding: 0;
        }

        header,
        footer {
            height: 100px;
            width: 100%;
            background-color: #bbbbbb;
        }

        .container {
            height: 300px;
            
            /* 聖杯佈局 */
            padding-left: 200px;
            padding-right: 300px; 
        }

        .container div{
            float: left;
            
            /* 聖杯佈局 */
            position:relative;
        }

        .left {
            width: 200px;
            height: 300px;
            background-color: #DC698A;

            margin-left: -100%;
            /* 聖杯佈局 */
            left:-200px;
        }

        .middle {
            width: 100%;
            height: 300px;
            background-color: #3EACDD;

        }

        .right {
            width: 300px;
            height: 300px;
            background-color: #8CB08B;
    

            margin-left: -300px;
            /* 聖杯佈局 */
            right:-300px;
        }
    </style>
</head>

<body>
    <header>頭部</header>
    <div class="container">
        <div class="middle">中間欄:內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容</div>
        <div class="left">左欄</div>
        <div class="right">右欄</div>
    </div>
    <footer>底部</footer>
</body>

</html>

2.2用flex實現聖杯佈局

實現方式:

(1)holyGrail啟用flex佈局,設置holyGrail中的header、container、footer在交叉軸上豎向排列(flex-direction:column;)

(2)container中的三欄佈局:container啟用flex佈局,設置container中的middle、left、right在主軸上橫向排列(flex-direction:row,預設值可以不設)。由於html中先寫的middle,所以為了讓left在最左邊,要設置left的order為這三欄中最小的,即-1(其他兩欄order為預設值0)

可以看出Flex佈局的實現方式更加簡單,也更加直觀。

實現效果:同上

實現代碼:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>聖杯佈局--flex</title>
    <style type="text/css">
        body {
            margin: 0;
            padding: 0;
        }
        .holyGrail{
            display: flex;
            flex-direction: column;
        }
        header,
        footer {
            height: 100px;
            width: 100%;
            background-color: #bbbbbb;

            flex: 1; /*flex:1; === flex:1 1 auto;*/
        }

        .container {
            height: 300px;
            
            display: flex;
            flex-direction: row;/*可不寫,預設值*/
            flex:1;/*需要可自動擴展*/
        }


        .left {
            width: 200px;
            height: 300px;
            background-color: #DC698A;

            order:-1;/*左邊欄放到最左邊*/
        }

        .middle {
            width: 100%;
            height: 300px;
            background-color: #3EACDD;

            flex:1;
        }

        .right {
            width: 300px;
            height: 300px;
            background-color: #8CB08B;
        }
    </style>
</head>

<body class="holyGrail">
    <header>頭部</header>
    <div class="container">
        <div class="middle">中間欄:內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容</div>
        <div class="left">左欄</div>
        <div class="right">右欄</div>
    </div>
    <footer>底部</footer>
</body>

</html>

三.固定欄-可擴展欄頁面佈局

實現效果:

img

實現代碼:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <title>flex</title>
    <style type="text/css">
        body {
            margin: 0;
            padding: 0;
        }

        .container {
            width: 300px;
            height: 200px;
            border: 1px solid blue;

            display: flex;
            flex-direction: column;
        }

        .nav {
            height: 50px;
            background-color: grey;

            display: flex;
            flex-direction: row;
        }

        .nav-item {
            min-width: 60px;
            border: 1px solid orangered;
        }

        .main {
            display: flex;
            flex-direction: row;
            flex: 1;
            /*main區域需要自動擴展*/
        }

        .main-left {
            width: 100px;
            /*main中的left區域固定*/
            background-color: #DC698A;
        }

        .main-right {
            background-color: #3EACDD;
            flex: 1;
            /*main中的right區域需要自動擴展*/
        }
    </style>
    <script src="http://code.jquery.com/jquery-3.1.1.min.js"></script>
</head>

<body>
    <div class="container">
        <div class="nav">
            <div class="nav-item">nav1</div>
            <div class="nav-item">nav2</div>
            <div class="nav-item">nav3</div>
        </div>
        <div class="main">
            <div class="main-left">固定欄:內容內容內容內容內容內容內容內容內容內容</div>
            <div class="main-right">可擴展欄:內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容內容</div>
        </div>
    </div>
</body>
<script type="text/javascript">
    (function run() {
        $(".container").animate({ width: 500, height: 300 }, 1500,
            () => {
                $(".container").animate({ width: 300, height: 200 }, 1500, run)
            }
        )
    }());
</script>

</html>

四.小結

本文主要提供了三個實例,來實際應用下flex的屬性。通過對比其他的實現方式,可以看出使用Flex佈局可以優雅地實現相同的CSS佈局問題。如有問題,歡迎指正。

此文已由作者授權騰訊雲+社區發佈

搜索關註公眾號「雲加社區」,第一時間獲取技術乾貨,關註後回覆1024 送你一份技術課程大禮包!


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

-Advertisement-
Play Games
更多相關文章
  • 這篇文章是因為,我們在做的後臺項目,裡面有大量的表格統計,這個不可能自己手寫,所以其中的表格使用的是jqgrid。 這個插件其實使用起來還是不錯的,裡面有很多的功能很贊。這篇博客就是自己的的一個記錄,也是對以後項目的一個參考。因為有一些代碼總是記不住。 首先就是引入這個插件所需要的js和css了,這 ...
  • 1.Strict Transport Security HTTP Strict Transport Security,簡稱為HSTS。 作用:允許一個HTTPS網站,要求瀏覽器總是通過HTTPS訪問它。 includeSubDomains,可選,用於指定是否作用於子功能變數名稱 支持HSTS的瀏覽器遇到這個 ...
  • JavaScript 系列博客(一) 前言 本系列博客為記錄學習 JavaScript 的學習筆記,會從基礎開始慢慢探索 js。今天的學習筆記主要為 js 引入、定義變數以及 JavaScript 中數據類型和數據類型之間的轉換。 引入 JavaScript 什麼是JavaScript 語言? Ja ...
  • 1字元串 replace("","")替換,前面為要替換什麼,後面為替換的內容只能替換一個 2DOM 時間三要素 事件源 誰身上發生的行為 事件 單機 雙擊 事件處理程式 當事件源發生事件時 是什麼結果 js處理事件 事件源.事件=事件處理程式 h5新增dom元素查找 querySelector(標 ...
  • [TOC] 一. 響應式編程 響應式編程,也稱為流式編程,對於非前端工程師來說,可能並不是一個陌生的名詞,它是 函數式編程 在軟體開發中應用的延伸,如果你對函數式編程還沒有一些感性的認知,那麼建議你先閱讀我曾經寫過的一篇入門文章 "【javascript基礎修煉(8)——指向FP世界的箭頭函數】" ...
  • 1.閉包:函數在調用的時候會形成一個私有的作用域,對內部變數起到保護的作用,這就是閉包。 2.變數銷毀: 1.人為銷毀 var a=12; a=null 2.自然銷毀 函數調用完成之後 瀏覽器會自動銷毀函數內的變數 3.閉包的作用? 1.保護變數 2.緩存數據 緩存數據有優勢也有劣勢:優勢是緩存數據 ...
  • 1.瀏覽器解析JavaScript原理特點: 1.跨平臺 2.弱類型 javascript 定義的時候不需要定義數據類型,數據類型是根據變數值來確定的. var a = 10; 數字類型 var a = true boolean類型 ( 強類型: 定義變數的時候需要定義變數的類型:例如java,C# ...
  • 預編譯的兩種情況 全局: 1.全局 直接是script標簽中的代碼,不包括函數執行 執行前: 1.首先生成一個GO(global object)對象,看不到,但是可以模擬出來用來分析 2.分析變數聲明,變數名為屬性名,值為undefined 3.分析函數聲明,函數名為屬性名,值為函數體,如果函數名和 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...