亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解關(guān)于flex-shrink如何計(jì)算的冷知識(shí)

  發(fā)布時(shí)間:2018-10-25 15:18:23   作者:ylzsmallsun   我要評(píng)論
本篇文章給大家?guī)?lái)的內(nèi)容是關(guān)于flex-shrink如何計(jì)算?flex-shrink的計(jì)算方法介紹,有一定的參考價(jià)值,有需要的朋友可以參考一下,希望對(duì)你有所幫助

假設(shè)有一個(gè)div內(nèi)包含三個(gè)子div1, div2, div3,寬度分別200px. 對(duì)于flex-grow對(duì)于剩余空間分配比例的計(jì)算相信用過(guò)flex布局的都非常熟悉了。這里還是簡(jiǎn)單列一下計(jì)算公式: 假設(shè)div1, div2, div3的flex-grow分別設(shè)置為 1,2,3. 現(xiàn)在假定外層div的寬度是800px, 那么剩下的800px - 3*200px = 200px如何分配給三個(gè)子div呢? 三個(gè)div額外分配的空間如下:

div1: 1 / (1 + 2 + 3) * 200px = 1/6 * 200px

div2: 2 / (1 + 2 + 3) * 200px = 2/6 * 200px

div3: 3 / (1 + 2 + 3) * 200px = 3/6 * 200px

 

重點(diǎn)來(lái)了,flex-shink到底是如何計(jì)算的呢?

flex-shink屬性主要是在外層div寬度不夠的情況下,子div收縮一定的空間來(lái)抵消不夠的那部分寬度。 舉個(gè)栗子,現(xiàn)在三個(gè)子div的寬度是600px, 但是我給外層div的寬度設(shè)置成500px, 那么不夠顯示的600-500 px應(yīng)該怎么讓子div們收縮掉這100px。這個(gè)時(shí)候flex-shrink就派上用場(chǎng)了,那具體怎么計(jì)算呢? 有人說(shuō)這個(gè)屬性跟flex-grow類似,計(jì)算方式也差不多吧(其實(shí)是有差異的)。但具體怎么算,很多人都說(shuō)不清,包括一個(gè)MDN, W3CShcool也沒給出具體公式。另外,我發(fā)現(xiàn)很多點(diǎn)贊數(shù)很多的文章,給出的計(jì)算公式是錯(cuò)誤的。這也是為什么我想要寫這邊文章的原因。

好了,不賣關(guān)子,來(lái)說(shuō)說(shuō)怎么計(jì)算收縮空間吧! 先貼出例子的代碼: html部分:

<div class="outer">
    <div class='div1'>1</div>
    <div class='div2'>2</div>
    <div class="div3">3</div>
</div>

css部分:

.outer {
  width: 500px;
  display: flex;
}
.outer div {
  height: 80px;
}

.div1 {
  flex: 1 1 100px;
  background: red;
}
.div2 {
  flex: 1 2 200px;
  background: yellow;
}
.div3 {
  flex: 1 3 300px;
  background: green;
}

先計(jì)算總權(quán)重TW = 100px * 1(flex-shrink) + 200px *2(flex-shrink) + 300px *3(flex-shrink) = 1400px 也就是每個(gè)div的寬度乘以flex-shrink系數(shù)的總和。

每個(gè)div收縮的空間為:div的寬度 * flex-shrink系數(shù)/ 總權(quán)重TW * 需要收縮的總寬度(在我們的例子中是600px - 500px = 100px)

所以各div最后的寬度計(jì)算公式如下:

div1最后的寬度 = 100px - 100*1/1400 * 100px = 92.86px

div2最后的寬度 = 200px - 200*2/1400 * 100px = 171.42px

div3最后的寬度 = 300px - 300*3/1400 * 100px = 235.72px

demo地址: https://jsfiddle.net/lingzhen/zg74bj8v/18/

截圖如下:

Tips: 看見別人的文章的一些公式時(shí),一定不要偷懶,自己寫個(gè)例子驗(yàn)證一下,不然明明被誤導(dǎo)了,卻還給點(diǎn)贊了收藏了。畢竟實(shí)踐出真知!

BTW: 這個(gè)屬性相對(duì)flex-grow來(lái)說(shuō)確實(shí)用的很少,所以很多人都沒研究過(guò)它具體到底是怎么算的。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 前端CSS Grid 布局示例詳解

    CSS Grid 是一種二維布局系統(tǒng),可以同時(shí)控制行和列,相比 Flex(一維布局),更適合用在整體頁(yè)面布局或復(fù)雜模塊結(jié)構(gòu)中,這篇文章主要介紹了前端CSS Grid 布局詳解,需要的朋
    2025-04-16
  • CSS Padding 和 Margin 區(qū)別全解析

    CSS 中的 padding 和 margin 是兩個(gè)非?;A(chǔ)且重要的屬性,它們用于控制元素周圍的空白區(qū)域,本文將詳細(xì)介紹 padding 和 margin 的概念、區(qū)別以及如何在實(shí)際項(xiàng)目中使用它們
    2025-04-07
  • CSS will-change 屬性示例詳解

    will-change 是一個(gè) CSS 屬性,用于告訴瀏覽器某個(gè)元素在未來(lái)可能會(huì)發(fā)生哪些變化,本文給大家介紹CSS will-change 屬性詳解,感興趣的朋友一起看看吧
    2025-04-07
  • CSS去除a標(biāo)簽的下劃線的幾種方法

    本文給大家分享在 CSS 中,去除a標(biāo)簽(超鏈接)的下劃線的幾種方法,本文給大家介紹的非常詳細(xì),感興趣的朋友一起看看吧
    2025-04-07
  • 前端高級(jí)CSS用法示例詳解

    在前端開發(fā)中,CSS(層疊樣式表)不僅是用來(lái)控制網(wǎng)頁(yè)的外觀和布局,更是實(shí)現(xiàn)復(fù)雜交互和動(dòng)態(tài)效果的關(guān)鍵技術(shù)之一,隨著前端技術(shù)的不斷發(fā)展,CSS的用法也日益豐富和高級(jí),本文將
    2025-04-07
  • css中的 vertical-align與line-height作用詳解

    文章詳細(xì)介紹了CSS中的`vertical-align`和`line-height`屬性,包括它們的作用、適用元素、屬性值、常見使用場(chǎng)景、常見問(wèn)題及解決方案,感興趣的朋友跟隨小編一起看看吧
    2025-03-26
  • 淺析CSS 中z - index屬性的作用及在什么情況下會(huì)失效

    z-index屬性用于控制元素的堆疊順序,值越大,元素越顯示在上層,它需要元素具有定位屬性(如relative、absolute、fixed或sticky),本文給大家介紹CSS 中z - index屬性的作用
    2025-03-21
  • CSS @media print 使用詳解

    文章詳細(xì)介紹了CSS中的打印媒體查詢@mediaprint包括基本語(yǔ)法、常見使用場(chǎng)景和代碼示例,如隱藏非必要元素、調(diào)整字體和顏色、處理鏈接的URL顯示、分頁(yè)控制、調(diào)整邊距和背景等
    2025-03-18
  • CSS模擬 html 的 title 屬性(鼠標(biāo)懸浮顯示提示文字效果)

    本文介紹了如何使用CSS模擬HTML的title屬性,通過(guò)鼠標(biāo)懸浮顯示提示文字效果,通過(guò)設(shè)置`.tipBox`和`.tipBox.tipContent`的樣式,實(shí)現(xiàn)了提示內(nèi)容的隱藏和顯示,感興趣的朋友一起
    2025-03-10
  • 前端 CSS 動(dòng)態(tài)設(shè)置樣式::class、:style 等技巧(推薦)

    本文介紹了Vue.js中動(dòng)態(tài)綁定類名和內(nèi)聯(lián)樣式的兩種方法:對(duì)象語(yǔ)法和數(shù)組語(yǔ)法,通過(guò)對(duì)象語(yǔ)法,可以根據(jù)條件動(dòng)態(tài)切換類名或樣式;通過(guò)數(shù)組語(yǔ)法,可以同時(shí)綁定多個(gè)類名或樣式,此外
    2025-02-26

最新評(píng)論