flex佈局基本語法

来源:https://www.cnblogs.com/jinyu59/archive/2019/04/02/10640149.html
-Advertisement-
Play Games

註 : 本文章按照菜鳥教程 Flex佈局語法教程為原型稍加修改,以方便自己學習. 菜鳥教程地址:http://www.runoob.com/w3cnote/flex-grammar.html 2009年,W3C提出了一種新的方案—-Flex佈局,可以簡便、完整、響應式地實現各種頁面佈局。目前,它已經 ...


註 : 本文章按照菜鳥教程 Flex佈局語法教程為原型稍加修改,以方便自己學習. 菜鳥教程地址:http://www.runoob.com/w3cnote/flex-grammar.html

2009年,W3C提出了一種新的方案—-Flex佈局,可以簡便、完整、響應式地實現各種頁面佈局。目前,它已經得到了所有瀏覽器的支持,這意味著,現在就能很安全地使用這項功能

1.什麼是flex佈局?

Flex是Flexible Box的縮寫,意為”彈性佈局”,用來為盒狀模型提供最大的靈活性.

flex佈局 : .box{display:flex;}

行內元素也可以使用flex佈局 : .box{display:inline-flex;}

Webkit內核的瀏覽器,必須加上-webkit首碼 : .box{display:-webkit-flex; display:flex;}

註意,設為Flex佈局以後,子元素的float、clear和vertical-align屬性將失效

2.基本概念

Flex容器(flex container) : 採用Flex佈局的元素,稱為flex容器.

Flex項目(flex item) : flex容器的所有子元素,自動成為容器成員,即flex項目.

容器的兩根軸線 : 水平的主軸(main axis), 垂直的交叉軸(cross axis).

主軸(main axis) : 開始位置->main start, 結束位置->main end, 項目預設沿主軸排列.

交叉軸(cross axis) : 開始位置->cross start, 結束位置->cross end

容器內的單個項目占據的主軸空間叫做->main size, 交叉軸空間叫做->cross size

3.FLex屬性

flex屬性分為容器屬性項目屬性.

容器屬性 : flex-direction, flex-wrap, flex-flow, justify-content, align-items, align-content

項目屬性 : order, flex-grow, flex-shrink, flex-basis, flex, align-self

3.1容器屬性

flex-direction : 決定主軸的方向(即項目排列方向)

  row : 水平方向,從左到右.(預設屬性)

  row-reverse : 水平方向,從右到左.

  column : 垂直方向,從上到下.

  column-reverse : 垂直方向,從下到上.

flex-wrap : 規定一條軸線排不下,如何換行.

  nowrap : 不換行(預設屬性)

  wrap : 換行,第一行在上邊

  wrap-reverse : 換行,第一行在下邊,(只行數排列相反,單行內依舊從左到右排列,每一行都是).

flex-flow : 結合flex-direction和flex-wrap,寫法如下 

  .box{flex-flow:column wrap-reverse}

justify-content : 定義項目在主軸上的對齊方式

  flex-start : 左對齊(預設值),項目以主軸的起點對齊

  flex-end : 右對齊,項目以主軸的終點

  center : 居中

  space-between : 兩端對齊,項目之間間隔相等

  space-around : 每個項目兩側的間隔相等。所以,項目之間的間隔比項目與邊框的間隔大一倍

align-items : 定義項目在交叉軸的對齊方式(僅單行,多行對齊由align-content定義)

  stretch : 如果項目未設置高度或設為auto,將占滿整個容器的高度(預設值)

  flex-start : 從上到下,以交叉軸的起點為基線,向終點延伸

  flex-end : 從下到上,以交叉軸的終點為基線,向起點延伸

  center : 交叉軸的中點對齊,項目的中點放在交叉軸的中點上

  baseline : 以一行中每個項目的第一行文字進行對齊.

 

align-content : 定義了容器內有多行項目時沿交叉軸的對齊方式, 如果項目只有一根軸線,該屬性不起作用

  stretch : 軸線占滿整個交叉軸(每行都有一條軸線), 預設屬性

  flex-start : 以交叉軸的起點對齊

  flex-end : 以交叉軸的終點對齊

  center : 以交叉軸的中點對齊

  space-between : 多行項目在交叉軸上間隔平均分佈

  space-around : 多行項目在交叉軸上兩側的間隔都相等。所以,項目在交叉軸上的間隔比項目與邊框的間隔大一倍

  註 : justify-content, align-items和align-content是容器的屬性,而不是項目的屬性,是設定一個容器內項目以軸線上的某一位置對齊

3.2項目屬性

order : 定義項目的排列順序,數值越小,排列越靠前.預設值為0,寫法如下

  .item{order:5}

flex-grow : 定義屬性項目放大比例,預設為1

  如果所有項目的flex-grow屬性都為1,則它們將等分剩餘空間(如果有的話)。如果一個項目的flex-grow屬性為2,其他項目都為1,則前者占據的剩餘空間將比其他項多一倍

flex-shrink : 定義項目縮小比例,預設為1

  如果所有項目的flex-shrink屬性都為1,當空間不足時,都將等比例縮小。如果一個項目的flex-shrink屬性為0,其他項目都為1,則空間不足時,前者不縮小.負值對該屬性無效

flex-basis : 定義了在分配多餘空間之前,項目占據的主軸空間(main size),瀏覽器根據這個屬性,計算主軸是否有多餘空間。它的預設值為auto,即項目的本來大小

  它可以設為跟width或height屬性一樣的值(比如350px),則項目將占據固定空間

flex : 結合flex-grow, flex-shrink 和 flex-basis的屬性, 預設值為0 1 auto, 推薦優先使用

  該屬性有兩個快捷值:auto (1 1 auto) 和 none (0 0 auto

align-self : 允許單個項目有與其他項目不一樣的對齊方式,可覆蓋align-items屬性, 預設值為auto,表示繼承父元素的align-items屬性,如果沒有父元素,則等同於stretch

  該屬性可能取6個值,除了auto,其他都與align-items屬性完全一致

  


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

-Advertisement-
Play Games
更多相關文章
  • 下圖展示了 LEFT JOIN、RIGHT JOIN、INNER JOIN、OUTER JOIN 相關的 7 種用法。 具體分解如下: 1、INNER JOIN(內連接) 2、LEFT JOIN(左連接) 3、RIGHT JOIN(右連接) 4、OUTER JOIN(外連接) 5、LEFT JOIN ...
  • 1.我們使用緩存時的業務流程大概為: 當我們查詢一條數據時,先去查詢緩存,如果緩存有就直接返回,如果沒有就去查詢資料庫,然後返回。這種情況下就可能出現下麵的一些現象。 2.緩存穿透 2.1什麼是緩存穿透 緩存穿透是指查詢一個一定不存在的數據,由於緩存是不命中時被動寫的,並且出於容錯考慮,如果從存儲層 ...
  • 最近做ogg數據同步,然後觸發器加工數據放入另外一張表,由於數據量很大,一分鐘幾萬條數據,由於一些條件欄位類型不匹配,引起ogg阻塞,比較頭大。最後分析發現性能問題。請看下圖: phmxxh是varchar2類型,note_id是integer類型,用to_char轉換以後,性能提高60倍以後註意避 ...
  • 筆記記錄自林曉斌(丁奇)老師的《MySQL實戰45講》 (本篇內圖片均來自丁奇老師的講解,如有侵權,請聯繫我刪除) 14) --count(*)這麼慢,我該怎麼辦? 有時你會發現,隨著系統中記錄數越來越多,select count(*) from t執行得也越來越慢。那麼今天,我們就來聊聊count ...
  • 寫代碼好多年了,發現大家的思路都是寫代碼、寫代碼、寫代碼,還弄了個稱號——碼農。 我是挺無語的,我的思路是——不寫代碼、不寫代碼、不寫代碼! 無聊的代碼為啥要重覆寫呢?甚至一寫寫好幾年。 舉個例子吧,要不然大家肯定很懵。 當我們剛開始學習資料庫編程的時候,我們會先寫一段代碼,實現往一個表裡添加數據的 ...
  • 目錄:zxing->encoding->EncodingHandler類 中修改 createQRCode方法 ...
  • 寫在前面 用Python加上一些數據分析,來證明《海王》好看。 《海王》一部電影帶你重溫《馴龍高手》《變形金剛》《星球大戰》《星河戰隊》《鐵血戰士》《安德的游戲》《異形》可能還借鑒了對手的《鋼鐵俠》與《黑豹》劇情,再稍稍帶一點《大魚海棠》的味道,配上一丟丟溫子仁式恐怖片套路,優秀的商業片,應該是DC ...
  • 粘貼自Christian.Cao 博客園地址 : https://www.cnblogs.com/QQ862668193/p/6893797.html 輸入框景背景透明:<input style="background:transparent;border:1px solid #ffffff"> 鼠 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...