html+css 浮动、清除浮动、什么是BFC?、如何开启BFC

这篇具有很好参考价值的文章主要介绍了html+css 浮动、清除浮动、什么是BFC?、如何开启BFC。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

浮动

介绍:

  • 其实早期的浮动是用来文字环绕图片效果,但是后来发现浮动还可以设置页面布局问题

  • 块元素在文档流中默认垂直排列,如果希望块元素在页面中水平排列,可以使块元素脱离文档流

特点:

  • 哪个元素设置浮动,哪个元素就会脱离文档流

  • 如果给上边的元素设置浮动时,下边的元素就会跑到上边元素的位置上,上边元素会覆盖住下边的元素(原因是上面的元素已经脱离了文档流,不占据位置)

  • 脱离文档流的元素,默认在父元素的顶部,不会超出父元素的内容

  • 脱离文档流的元素不再区分块和行内,统一会变成行内块

  • 无论浮动的元素是右还是左浮动,下面的元素都会默认朝左上角

  • 如果父元素设置了padding,那么浮动的子元素不会超出padding以外

  • 元素浮动主要就是为了元素之间在一行排列(页面布局问题)

  • 浮动的元素并不是根据上下排列的顺序来设置左右浮动,每个元素可以任意设置浮动位置

  • 如果上下元素都浮动了,他们就会按照顺序进行排列

  • 如果上边有元素未设置浮动,下边设置浮动的元素会被挡住

清除浮动

clear属性

清除浮动,指定段落的左侧或右侧不允许浮动的元素

属性 描述
right 清除向右浮动的元素
left 清除向左浮动的元素
both 清除左右浮动的元素

方法一:额外标签法(w3c提出,不推荐)

是给最后一个浮动的元素后面添加一个空标签,给空标签设置clear属性清除浮动

原理:

额外标签法主要就是调整额外标签的自身,通过调整自身来使自己不要和浮动元素排列在一起。

缺点:

如果页面中出现很多的浮动,就需要添加很多空标签清除浮动,就会导致很繁琐,所以不推荐

方法二:给父元素添加overflow属性(不推荐)

给父元素添加overflow属性非visible属性值(auto、scroll、hidden)

缺点:

如果子元素内容过多会出现隐藏问题,或者页面布局发生改变,不常用此属性

方法三:给父元素设置after伪元素

伪元素创建的元素是行内元素

其实原理和额外标签法类似

        /*只写一个冒号是为了兼容其他浏览器不支持::*/     
      .clearfix:after {
            /*伪元素创建的元素是行内元素*/
            /*content值要加一个小点,为了防止低版本浏览器解析时出现空隙问题*/
            content: ".";
             /* 转化为块元素*/
            display: block;
            height: 0;
            /*隐藏content里面的小点*/
            visibility: hidden;
            /*清除浮动*/
            clear: both;
        }
            /*以下是为低版本浏览器做的适配*/
       .clearfix {
            *zoom: 1;
            /*  星号代表了只有ie6和ie7才会解析这段代码,zoom是ie6和ie7的清除浮动方法  */
        }

方法四:给父元素添加双伪元素after before (推荐)

 .clearfix:before,
        .clearfix:after {
            content: "";
            display: table;
            /*触发BFC*/
            clear: both;
        }

BFC

页面元素中的隐含属性:Block Formatting Context 即块格式化上下文,简称BFC

当开启元素的BFC以后,元素会变成一个独立的布局区域,不会在布局上影响到外面的元素

BFC 理解为一个封闭的大箱子,箱子内部的元素不会影响到外部。

开启BFC后,元素将会具有如下的特性:
  1. 父元素的垂直外边距不会和子元素重叠

  2. 开启BFC的元素不会被浮动元素所覆盖

  3. 开启BFC的元素可以包含浮动的子元素(可解决高度塌陷)

如何开启元素的BFC
  1. 设置元素浮动(不推荐)

    • 使用这种方式开启,虽然可以撑开父元素,但是会导致父元素的宽度丢失

    • 而且使用这种方式也会导致下边的元素上移,不能解决问题

  2. 设置元素为inline-block(不推荐)

    • 可以解决问题,但是会导致宽度丢失,不推荐使用这种方式

  3. 将元素的overflow设置为一个非visible的值 (推荐)

    • scrollautohidden

  4. 设置元素绝对定位

    • 元素也会脱离文档流,虽然可以撑开父元素,但是会导致父元素的宽度丢失

    • 而且使用这种方式也会导致下边的元素上移,不能解决问题

推荐方式:将overflow设置为hidden是副作用最小的开启BFC的方式文章来源地址https://www.toymoban.com/news/detail-785207.html

到了这里,关于html+css 浮动、清除浮动、什么是BFC?、如何开启BFC的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【CSS】网站 网格商品展示 模块制作 ( 清除浮动需求 | 没有设置高度的盒子且内部设置了浮动 | 使用双伪元素清除浮动 )

    绘制的如下模块 : 在上面的盒子中 , 没有设置高度 , 只设置了一个 1215px 的宽度 ; 在列表中每个列表项都设置了 浮动 ;   之前的盒子都设置了高度 , 因此其中虽然设置了浮动 , 但不会影响到后续的页面布局 ; 上述模型中 , 没有设置高度 , 并且设置了浮动 , 如果不清除浮动 , 后

    2024年02月10日
    浏览(49)
  • 【CSS】课程网站 网格商品展示 模块制作 ③ ( 清除浮动需求 | 没有设置高度的盒子且内部设置了浮动 | 使用双伪元素清除浮动 )

    如果盒子没有设置高度 , 并且盒子中还设置了浮动 , 如上一篇博客 【CSS】课程网站 网格商品展示 模块制作 ② ( 网格商品展示盒子模型测量及样式 | 处理列表间隙导致意外换行问题 | 代码示例 ) 中绘制的如下模块 : 在上面的盒子中 , 没有设置高度 , 只设置了一个 1215px 的宽度

    2023年04月09日
    浏览(40)
  • HTML5+CSS3学习笔记(九)前端页面六大布局(文档流布局、浮动布局、定位布局、表格布局、弹性布局、网格布局)

    本系列更多文章,可以查看专栏 HTML+CSS学习笔记 块级元素自上至下垂直排列,行内元素自左至右水平排列 块级元素独占一行,行内元素不会另起一行 默认情况下,height和width决定内容区的大小;内容区、内边距和边框构成可见区域的大小;外边距决定元素的位置 更多内容可

    2024年02月02日
    浏览(60)
  • 前端系列第4集-解释下浮动和它的工作原理,清除浮动的方法

    浮动是CSS布局中的一个重要概念,它可以让元素脱离标准文档流,并且可以让其他元素环绕在其周围。通常情况下,浮动用于创建多列布局或者图像与文字混排的效果。比如,我们可以使用浮动来实现一个左侧导航栏、右侧主体内容的页面布局。 浮动的工作原理很简单。当一

    2023年04月08日
    浏览(42)
  • Web网页制作-知识点(4)——CSS盒子模型、弹性盒模型(flex box)、文档流、浮动、清除浮动、定位、圆角、阴影

    目录 CSS盒子模型 概念 弹性盒模型(flex box) 内容 父元素上的属性 display属性 flex-direction属性 justify-content属性 align-items属性 子元素上的属性 flex 文档流(标准流) 浮动 定义 浮动的原理 清除浮动 浮动的副作用 父元素设置高度 overflow清除浮动 伪对象方式 定位 定义 相对定位

    2024年02月11日
    浏览(62)
  • 前端三件套之css(5) BFC

    目录 什么是BFC 能触发BFC的标签或属性 BFC布局的标准规则 BFC全称(Block formatting context) 意为:\\\"块级格式化上下文\\\"。  它就像我们学校分班级一样,虽然都是一个学校,但是每个班是独立的,不相干扰的。 例如上述的三个div,\\\"main\\\" 有两个子标签 \\\"left\\\" 和 \\\"right\\\" ,BFC的作用就是分

    2024年02月12日
    浏览(38)
  • CSS中的BFC是什么?

    BFC(Block Formatting Context)块格式化上下文 ,简单来说就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。 我们经常在写CSS时不知不觉就会触发了BFC: 根元素,即HTML元素 浮动元素:元素的float不是none,指定float为left或者right就可以创建BFC 绝对定位

    2024年02月14日
    浏览(34)
  • html&CSS-----浮动

      目录 前言:  浮动 1.浮动的效果  2.浮动的特点  3.浮动的写法 4.浮动的原理 5.浮动的作用  6.案例 7.浮动的缺陷与解决方式 浮动问题  解决方式  8.补充说明         浮动是html里面重要的一部分,前面我们学习了三种元素的类型(块级元素,行内元素和行内块元素),今

    2024年02月16日
    浏览(41)
  • 前端中的BFC是什么?

    BFC(Block formatting context)直译为\\\"块级格式化上下文\\\"。它是一个独立的渲染区域,只有Block-level box参与, 它规定了内部的Block-level Box如何布局,并且与这个区域外部毫不相干。 MDN给出的解释是:BFC是Web页面的可视CSS渲染的一部分,是块盒子的布局过程发生的区域,也是浮动元素

    2023年04月09日
    浏览(31)
  • HTML--CSS--浮动布局及定位布局

    块元素独占一行 行内元素在有多个的时候,就是从左到右排在一行 块元素包括: div , p , hr 行内元素: span , i , img float 属性: left 向左 right 向右 作用我目前看起来就是浮动元素的宽度是由内容决定的,而不是占满 效果: 但是需要注意,如果给定的宽度不够,效果会偏差:

    2024年01月19日
    浏览(59)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包