Shrink-to-fit(自适应宽度)怎么写?
来源:简书 发布时间:2020-05-22 13:41:37

自适应宽度是指当未明确设定容器的宽度(或外边距设为auto)时,在特定的情况下容器的宽度会根据情况自行设定,而设定的结果往往并不是我们想要的。

W3C规范中描述了几种shrink-to-fit的情况

10.3.5 Floating, non-replaced elements

10.3.7 Absolutely positioned, non-replaced elements

10.3.8 Absolutely positioned, replaced elements

10.6.4 Absolutely positioned, non-replaced elements

规范中提到了一个基本概念,我们先来了解一下。

replaced elements & non-replaced elements

css把html元素分为了两类:不可替换元素和可替换元素。

1.可替换元素:

CSS 里,可替换元素是这样一些元素, 其展现不是由CSS来控制的。这些外部元素的展现不依赖于CSS规范。 典型的可替换元素有 img、 object、 video 以及 textarea、input这样的表单元素。 一些元素,比如audio和 canvas ,只在一些特殊情况下是可替换元素。 使用了 CSS content 属性插入的对象被称作匿名的可替换元素。

2.不可替换元素:

反之,则为不可替换元素。

了解了概念后,我们回归主题。shrink-to-fit的情况有多种,这里介绍一种最常见的情况,即不可替代元素浮动时的自适应宽度(Floating, non-replaced elements),听起来有点抽象,但你可能经常遇到。先看一个例子:

html&css

undefined

this is 1th line this is 2th line this is 3th line this is 4th line

sub2 block

这段样式定义了一个outer容器,背景为黑色且宽度为800px,它里面还有一个内部容器inner,无宽度且左浮动,inner里有两个小块sub1和sub2。

那么问题来了,请问inner,sub1,sub2具体的宽度为多少?

先看效果图再回答:

结果应该会出乎你的意料:inner(红色背景)的宽度并不是outer(黑色背景)的宽度(正常情况下应该可以继承父容器的宽度),因而sub1和sub2比我们预想的要小得多。

再回答这个问题之前,我们先试图修改一下,看能否从中找到出现这个问题的原因。经过调试,发现两种最简单的方案可以解决这个问题:

1.给inner加宽度width: 100%;

2.取消inner的浮动。

解决后的效果如下:

这的确是我们想要的,可这却巧妙地'躲'过了不可替换元素浮动这个场景。老实讲,我多次遇到过这个场景,但是无非也就是利用上述两个方案去尝试,可并不知晓真正的原因,于是还是啃了一下W3C有关这方面的规范,规范的描述如下:

首先不说英文的问题,单纯的'Roughly'和‘CSS 2.1 does not define the exact algorithm’这两句就让人哭笑不得,然后还给出了shrink-to-fit的一个公式:

min(max(preferred minimum width, available width), preferred width)

呵呵,然并卵啊,天知道这三个值怎么算。

再网上google一下,发现很多人都遇到这个问题,但也是读不懂规范,也有人把上面一段翻译了一下,大家可以看看:

CSS2.1 并未给出 preferred minimum width、available width 和 preferred width 确切算法,通常,将内容中非明确的换行外的其他部分强制不换行来计算 preferred width;反之,尝试将内容尽可能的换行,以得到 preferred minimum width;available width 即该元素的包含块的宽度减去 'margin-left','border-left-width','padding-left','padding-right','border-right-width','margin-right' 的值以及任何存在的纵向滚动条的宽度。

已被这段翻译绕晕的请举手。。。。。。。。。。。。。

再次回归主题,经过近一个小时的摸索,终于让我把这段难懂的英文捋顺了:

这里有三个参数,分别为:preferred minimum width, available width, preferred width.只需关心preferred width的计算方式即可,preferred width的计算方式如下:

让元素内容强制不换行后的最大宽度即为shrink-to-fit后的宽度

具体拿上面的例子,inner中的sub1的内容由于宽度不够被换行了,将其强制不换行算出的宽度就是inner自适应的宽度(inner本身没设宽度喔~),如何强制不换行也很简单,慢慢的将sub1的宽度调大,就会发现调至100%时恰好足够用一行来现实其内容,这时内容的宽度就是inner自适应后的宽度。直接上图:

总结:对于浮动或者特殊的定位方式,推荐显式的设置容器宽度,避免出现意想不到的结果

作者:Pursue

 

 

.outer {

 

width: 800px;

 

background: black;

 

overflow: hidden;

 

}

 

.inner {

 

float: left;

 

background: red;

 

}

 

.sub1 {

 

width: 26%;

 

background: blue;

 

}

 

.sub2 {

 

width: 50%;

 

background: green;

 

}

 

 

标签: shrinktofit

猜你喜欢

典当铺回收黄金要什么手续 回收黄金需要什么证件?

近年来典当行业也在迅速发展,黄金是非常好的一种投资选择,因此在典当行业中金质典当也很常见。那...更多

2021-08-31 14:53:50

买一口价的黄金好还是以克算划算 你会怎样选择?

提起黄金首饰,这属于我们日常佩戴的最普遍的饰品,关于黄金首饰的价格,相信一直关注国际金价的朋...更多

2021-05-08 16:07:09

华能水电(600025.SH)公布消息:一季度完成发电量1

华能水电(600025 SH)公布,根据公司统计,截至2021年3月31日,公司装机容量2318 38万千瓦。2021年...更多

2021-04-06 16:39:30

中房股份(600890.SH)2020年度净亏损5084.53万元

中房股份(600890 SH)发布2020年年度报告,实现营业收入1090 40万元,同比下降91 42%;归属于上市...更多

2021-04-02 09:26:16

中国地利(01387.HK)年度纯利下降65.2% 基本每股

中国地利(01387 HK)发布公告,截至2020年12月31日止年度,实现收入人民币14 501亿元,同比增长2 ...更多

2021-03-31 14:15:01

中国地热能(08128.HK)年度亏损收窄至2.42亿港元

中国地热能(08128 HK)公告,截至2020年12月31日止年度,公司收益2 3亿港元,同比减少33 2%;公司...更多

2021-03-30 08:57:49

中金辐照(300962.SZ)IPO网上摇号中签结果出炉:中

中金辐照(300962 SZ)披露首次公开发行股票并在创业板上市网上摇号中签结果,具体如下:凡参与此次...更多

2021-03-29 14:33:06

智傲控股(08282.HK)年度亏损扩大440.53% 每股

智傲控股(08282 HK)公布,截至2020年12月31日止12个月,集团实现收益5130 4万港元,同比下降36 0...更多

2021-03-26 13:38:26

贝达药业(300558.SZ)公布消息:贝成投资质押150万股

贝达药业(300558 SZ)公布,公司今日接到股东浙江贝成投资管理合伙企业(有限合伙)(贝成投资)函告,...更多

2021-03-23 13:31:55

金石投资(00901.HK)宣布消息:正在考虑通过股份交

金石投资(00901 HK)宣布,公司正在考虑可能将对不少于五家具有强劲增长潜力的上市或拟上市的公司("...更多

2021-03-19 09:16:32