时间:2021-07-01 10:21:17 帮助过:4人阅读
官方定义:
float 属性定义元素在哪个方向浮动。以往这个属性总应用于图像,使文本围绕在图像周围,不过在 CSS 中,任何元素都可以浮动。浮动元素会生成一个块级框,而不论它本身是何种元素。如果浮动非替换元素,则要指定一个明确的宽度;否则,它们会尽可能地窄。假如在一行之上只有极少的空间可供浮动元素,那么这个元素会跳至下一行,这个过程会持续到某一行拥有足够的空间为止。
看着这一些定义似懂非懂,要是真在使用的时候,还是有一些不懂的地方。现对其官方定义进行归纳总结一下他的特点:
补充说明:普通流(也称标准流)规定元素是从左到右、从上到下顺序排列。
下面我们通过实例来逐一进行验证,当然不排除在某种特殊的情况下我的归纳总结不成立,不过我是没有想出来的。
3. 将div1的高宽度去掉,他就会根据你的文字宽度自撑了,如果不给高宽度能有多窄就有多窄,其实与元素设为inner-block且不设定高宽度效果一样都是自撑,后续还会介绍该属性。在某种意义上来讲设置元素浮动与行内块是一个道理,只不过浮动是可以改变元素方向而已。
4. 设置div1 div2 两个元素向左浮动,根据我归纳总结的,如果浮动元素碰到父级元素的边框或碰到另一个浮动元素边框停止浮动。div1就是碰到父级元素容器的边框 、div2就是碰到div1的边框停止浮动,如果猜想有问题,应该是div2元素是要覆盖div1的元素,可是没有,证明我归纳是正确的。
5. 设置div1 元素向左浮动,根据我归纳总结的,如果指定浮动元素后,后续非浮动块级元素会紧跟着浮动元素后面,并会自动填充元素的宽度。其实div2的宽度是100%了,div1是浮动在div2元素上面的。上面说过浮动元素是不占文档任何空间的。