flex這些問題應該被理解

来源:https://www.cnblogs.com/yuyunhao/archive/2022/04/03/16094927.html
-Advertisement-
Play Games

flex三連問,幫助我們更好的理解佈局利器 問題: flex的值 auto, none, 0, 1, initial分別是什麼?有什麼作用?有什麼表現? flex-basis和width的區別?單值flex-basis:0與auto的區別?flex-basis:100px與width:100px一樣 ...


flex三連問,幫助我們更好的理解佈局利器

問題:

  1. flex的值 auto, none, 0, 1, initial分別是什麼?有什麼作用?有什麼表現?
  2. flex-basis和width的區別?單值flex-basis:0與auto的區別?flex-basis:100px與width:100px一樣嗎?
  3. 怎樣理解剩餘空間?

解決:

問題一:

flex的值 auto, none, 0, 1, initial分別是什麼?

  • flex: auto 為 1 1 auto

  • flex: none為 0 0 auto

  • flex: 0為 0 1 0

  • flex: 1為 1 1 0

  • flex: initial為 0 1 auto

提一嘴,我認為重要的是這個flex的預設值,也就是initial。因為多數情況,我們都是在預設值上修改,其他再不容易記的東西,也會有了參照而變得游刃有餘。

上述五種情況的作用及表現什麼?

  1. flex:initial(預設值)
  • 父盒子設置為彈性盒,子元素預設就為initial,一般用於還原預設值

  • 表現為不會隨之增大,會隨之減小,寬度參照自身

  1. flex:1
  • 一般用於等分(分配剩餘空間後,表現為等分)

  • 表現為會隨之增大,會隨之減小,寬度內容區最小寬度(分配剩餘空間前)

  1. flex:0
  • 不常用

  • 表現為不會隨之增大,會隨之減小,寬度內容區最小寬度(分配剩餘空間後)

  1. flex:auto
  • 一般用於文字越長,元素越寬的場景

  • 表現為會隨之增大,會隨之減小,寬度參照自身

  1. flex:none
  • 一般用於保持元素自身寬度,且文字不換行

  • 表現為不會隨之增大,不會隨之減小,寬度參照自身

問題二:

flex-basis和width的區別?單值flex-basis:0與auto的區別?

  • 兩者都是用於改變彈性盒元素的寬度

  • flex-basis比width優先順序更高;

    • 如果flex-basis為auto,那麼元素就會參照width

    • 如果flex-basis不為auto(如:0,200px等),那麼元素就會忽略width(即使你設置了width),採用flex-basis的值

flex-basis:100px與width:100px(彈性盒可縮減為前提條件)一樣嗎?

  • 首先說結論,不一樣!!!

    • width:100px + flex-basis:auto === 元素100px
    • content + flex-basis:100px === maxcontentflex-basis:100px) >= 元素100px
  • 剖析一下,有以下兩種情況:

    1. 元素flex-basis為auto時,width設為100px,那麼當縮小彈性盒時,元素始終為100px,不會變化。那麼如果該元素內容區寬度超過100px(比如內嵌的圖片,font-size大小等),那麼也不會撐大該元素,它就是個定值100px

    2. 元素flex-basis不為auto時,width設為多少都沒用,優先取flex-basis的值。若flex-basis為100px,那麼如果該元素內容區寬度超過100px(比如內嵌的圖片,font-size大小等),那麼與設置width結果相反,會撐大該元素,最後計算的寬度會大於100px。

  • width就是寫死,無論怎麼變,該元素就是這麼寬;flex-basis意思是,元素大概是這麼寬,如果有意外情況,那麼我還會改變。

    • 舉個小慄子幫助理解下:你晚上在加班,女朋友要讓你陪她一個小時,但是女人的嘴,騙人的鬼,指不定耽誤多長時間呢。然後。。。

      • width的理解:我是個負責任的男人,一個小時一分不多一分不少,不會因為任何說法改變這一個小時。

      • flex-basis的理解:女朋友比任何事都重要,如果她不鬧騰,那麼一個小時就準時結束,否則,我只能由著她的性子來了。唉,折騰到明早也有可能,沒辦法,誰讓她最重要呢?

問題三:

怎樣理解剩餘空間?

  1. 開啟彈性盒的元素的寬度為總空間

  2. 去掉所有子元素的固定寬度後,剩餘的空間就叫做剩餘空間

  • 子元素有width屬性,那麼去掉width就是剩餘空間

  • 子元素有flex-basis:100px

    • 如果100px小於總寬度,那麼去掉flex-basis就是剩餘空間

    • 如果100px大於總寬度,那麼沒有剩餘空間

      • 如果縮減繫數flex-shrink為0,那麼元素就是100px,表現為超出父盒子

      • 如果縮減繫數flex-shrink不為0,元素的最終寬度也要少於100px


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

-Advertisement-
Play Games
更多相關文章
  • Linux 0.11主要包含文件管理和進程管理兩個部分。進程管理包括記憶體管理、進程管理、進程間通信模塊。文件管理包含磁碟文件系統,打開文件記憶體數據。磁碟文件系統包括空閑磁碟塊管理,文件數據塊的管理,文件元數據的管理,樹形結構目錄。打開文件記憶體數據包括文件描述符表、file文件表、inode節點表。 ...
  • 在 Docker 中構建鏡像最常用的方式就是使用 Dockerfile。Dockerfile 是一個用來構建鏡像的文本文件。 官方文檔:https://docs.docker.com/engine/reference/builder/ 一、Dockerfile常用命令 對官方文檔的一個翻譯: 1.1 ...
  • Windows Registry Editor Version 5.00 [-HKEY_CLASSES_ROOT\CompressedFolder\CLSID] [-HKEY_CLASSES_ROOT\SystemFileAssociations\.zip\CLSID] cab文件類似。 ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 背景 centos7使用yum install mariadb-server命令安裝的預設版本是5.5的,這是因為系統預設源只有5.5的版本,所以我們去增加一個10.6的源 增加源 去mariaDB官網找到對應的源 Download MariaD ...
  • 1、資料庫概述及數據準備 1.1、SQL概述 SQL,全稱Structured Query Language,SQL用來和資料庫打交道,完成和資料庫的通信,SQL是一套標準。(90%以上的SQL都是通用的)。 SQL:結構化語言,是一門標準通用的語言。SQL屬於高級語言。 SQL語句在執行的時候,實 ...
  • 本文將引導你如何使用ZEGO Flutter SDK 快速輕鬆的構建一個跨平臺音視頻聊天應用,減少開發成本。 ...
  • 最近,有朋友私信讓我就`git 使用`做篇文章分享,分享一下我在日常工作中是如何使用`git`的。我當場就收費兩包辣條,最後討價還價,朋友用1.5包辣條騙到了這篇文章,等他欣喜的走了我打算直接分享出來,氣死這個吝嗇鬼,當然最終還是希望本文對你有所幫助。 ...
  • 用戶流失了,觸達難? 活動做了那麼多,轉化仍然很低? 運營也需要提前思考,預測用戶動向,提前精準觸達,才能事半功倍。結合HMS Core分析服務的預測服務和智能運營,洞察營銷時機,實時落地營銷策略,提升用戶運營效率。 預測服務擁有精準預測模型和深度人群洞察,支持查看近一周的預測準確率,幫助運營者做出 ...
一周排行
    -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# ...