CSS——浮动

一、浮动简介

浮动:一种布局方式,使元素脱离文档流

一旦元素脱离文档流了,它就不具备元素在文档流中的特点

块也不会独占一行了,行内也能设置宽高了,行内块也没有3像素的问题了

这种布局方式主要用于pc端,后期也会学更优秀布局方案,一定程度上替代了浮动

但不会完全替代,因为浮动的兼容性很好

设置浮动 float: ;

  • 可选值

left 向左浮动

right 向右浮动

none 不浮动

二、浮动特点

1、设置元素浮动后,元素脱离文档流,元素原来在文档流中位置就不在了,下面的元素会立即补充上去

2、元素浮动后并不会乱跑,会局限在父元素范围内,会紧跟着上一个兄元素如果上面的兄元素也浮动,他们就一起横向排列,如果上面的兄元素不浮动,浮动元素会被挡住

3、元素脱离文档流后,不再局限元素在文档流中的特点,行内可设宽高,块不再独占一行,行内块没有3像素问题

4、浮动的元素不会盖住文字,文字会自动环绕在浮动元素的周围,所以我们可以通过浮动来设置文字环绕图片的效果

三、高度塌陷

1、浮动带来的问题:高度塌陷

一般情况下,块元素高度如果不设置,会被内容撑开,此时设置其子元素浮动,子元素脱离文档流,不再占据原来在文档流中的位置,也就撑不开父元素的高度了,导致父元素高度的丢失,进而影响到整个页面的布局。

2、解决方案

(1)给父元素设置高度,最简单,最直接

(2)开启父元素的隐藏属性BFCoverflow:hidden

(3)给父元素的最后添加一个块标签,清除浮动带来的影响

(4)定义类,添加空白表格,清除浮动: clear: ;

  • 可选值

left:清除左侧浮动带来的影响

right:清除右侧浮动带来的影响

both:清除两侧浮动带来的影响

css 复制代码
      /* 解决外边距折叠 */
      .clear::before {
        content: "";
        display: table;
      }
      /* 解决高度塌陷 */
      .clear1::after {
        content: "";
        display: table;
        clear: both;
      }
      /* 整合以上2个类 */
      .clearfix::before,
      .clearfix::after {
        content: "";
        display: table;
        clear: both;
      }
相关推荐
llz_1122 小时前
web-第二次课后作业
前端·后端·web
vipbic7 小时前
别再把“做个H5”挂嘴边了:这个词,官方压根就没有定义过
前端
ZC跨境爬虫9 小时前
跟着 MDN 学CSS day_39:(Flexbox 弹性盒子核心机制)
前端·css·ui·html·tensorflow
小陈同学呦9 小时前
前端如何处理订单状态导航的数据竞态问题
前端·javascript
喵个咪9 小时前
GoWind Toolkit 前端代码生成|Vue3(ElementPlus/Vben)、React(AntDesign)全自动一键生成教程
前端·vue.js·react.js
摆烂大大王11 小时前
玩转 OpenClaw:用 TaskFlow + Heartbeat 打造自动化工作流
前端·人工智能·自动化
zhangxingchao11 小时前
AI 大模型核心六:量化、Workflow 与 Agent、多轮 RAG
前端·人工智能·后端
梦想的颜色11 小时前
TypeScript 完全指南(上):从零开始掌握类型系统
前端·typescript
之歆11 小时前
Day01_ES6+ 专业指南:从基础到实战的现代JavaScript开发(下)
前端·javascript·es6
lichenyang45311 小时前
鸿蒙 MVVM 实战:从 Demo 到工程化,聊聊登录、状态管理与埋点系统设计
前端