浮动元素详解

为什么需要浮动元素?

1. 行内元素(包括文字、input、button等等)环绕浮动元素,这也是float设计之初的目的,可以实现文字环绕图片等效果
2. 较早时期用来进行页面布局,现在有了inline-block、flex、grid等等更方便的方法

浮动元素布局原理

浮动元素会根据属性值向左或向右浮动,浮动元素会脱离普通文档流,进入浮动流,浮动流内的浮动元素可以左右移动,直至外边缘碰到包含块或其他浮动元素,会使得块级元素无视浮动元素且行内元素环绕浮动元素(了解过层叠上下文的同学就会知道浮动层实际介于块级元素层和行内元素层之间)

下面我们来看看各种浮动情况下的效果,页面元素、效果如下:

<div class="app">
    <div class="div1">div1</div>
    <div class="div2">div2</div>
</div>
  • 两个子元素均为float:left

    这里我们发现:左浮动时,为由右向左移动,且下一行元素移至上一行时同样是由右向左

  • 两个子元素均为float:right

    同理,右浮动时,为由左向右移动,且下一行元素移至上一行时同样是由左向右

  • 仅第二个子元素为float:right

    这里我们发现:若浮动元素的上个块级元素不为浮动元素,其不可向上移动(上个元素为行内或行内块级时会上移)

清除浮动

clear:left/right/both

即不允许左/右两边有浮动元素,当前行上不会再又浮动元素(注意用于设置clear样式的div不要设置float)

常用方式:

// 在需要清除浮动的元素的上侧或下侧添加div,并设置clear样式
.clear{
  clear: both;
}
// 设置包含浮动元素的容器元素的伪元素
.wrapper-clear::after{
  content: '';
  display: block;
  clear: both;
}
// 设置父元素overflow: auto
// 将父元素也变为BFC
  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
CSS中的浮动属性(float)用于控制元素在其父元素中的位置和布局。通过设置浮动属性,我们可以将元素从正常的文档流中脱离出来,使其沿着父元素的左侧或右侧浮动浮动属性有三个可能的取值:left、right和none。默认值为none。 - 当设置为left时,元素会向左浮动,其周围的内容会围绕在右侧。 - 当设置为right时,元素会向右浮动,其周围的内容会围绕在左侧。 - 当设置为none时,元素不进行浮动,恢复正常的文档流。 浮动元素会具有块级元素的特性,即会占据一定的空间,并且会从左到右或从右到左排列。浮动元素不会占据父元素中的空间,所以其他元素会填充浮动元素的位置。 除了浮动属性外,我们通常还需要配合一些其他属性来控制浮动元素的行为: - clear属性用于清除浮动对后续元素的影响。可以设置为left、right、both或none来指定在浮动元素的左侧、右侧或两侧不允许出现浮动元素。 - overflow属性可以用于包含浮动元素,通过设置其值为auto或hidden,可以触发父元素的块级格式化上下文,使其包含浮动元素。 需要注意的是,使用浮动属性可能会导致一些布局上的问题,如高度塌陷(clearfix问题)和重叠等。为了避免这些问题,可以使用一些技巧和清除浮动的方法。 总而言之,浮动属性是CSS中用于实现元素布局的重要属性,可以使元素浮动到指定位置,并影响周围元素的布局。然而,由于其一些潜在的问题,现代CSS布局技术更倾向于使用flexbox和grid布局来代替浮动

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值