13、前端开发:CSS知识总结——浮动及高度塌陷

简介: 13、前端开发:CSS知识总结——浮动及高度塌陷

1、浮动定义

float(浮动),会使元素向左或者向右移动,其周围的元素也会重新排列。


2、浮动用法

可选值: none    默认值,元素不浮动


                 left    元素向左浮动


               right    元素向右浮动


float可以使块元素水平布局


3、浮动特点

1.浮动元素脱离文档流之后不会在占用文档流的位置,它下面的元素会立即向上移动


举例:

<head> 
  <style>
    .box{background-color: red;
    height: 200px;
    width: 200px;}
    .box1{background-color: yellow;
    height: 400px;
     width: 400px;}
  </style>
</head>
<body>
  <div class="box"></div>
  <div class="box1"></div>
</body>


2.png

正常情况下,黄色方块 是 在红色方块下面的下面


当我们为红色方块设置左浮动时, 黄色方块会向上移动


 

<head>
    <style>
        .box{background-color: red;
        height: 200px;
        width: 200px;
        float: left;}
        .box1{background-color: yellow;
        height: 400px;
        width: 400px;} 
    </style>
</head>
<body>
    <div class="box"></div>
    <div class="box1"></div>
</body>

 



1.gif

2.浮动的元素会移动到父元素的左侧或者右侧


 

<head>
    <style>
        .fu{width: 800px;
        height: 800px;
        border:1px solid blue;
        margin: 0 auto;}
        .box{background-color: red;
        height: 200px;
        width: 200px;
        float: left;}
        .box1{background-color: yellow;
        height: 400px;
        width: 400px;
        float: right;}
    </style>
</head>
<body>
    <div class="fu" >
    <div class="box"></div>
    <div class="box1"></div>
</div>

 


2.png

3.浮动元素不会溢出父元素


4.浮动元素上面是一个没有浮动的块元素,则浮动元素无法上移


举例


红色方块不设置浮动


给黄色方块设置左浮动


 

<head>
    <style>
        .box{
            background-color: red;
            height: 200px;
            width: 200px;}
        .box1{
            background-color: yellow;
            height: 400px;
            width: 400px;
            float: left;}
    </style>
</head>
<body> 
  <div class="box"></div>
  <div class="box1"></div>
</body>




1.gif

红色方块不设置浮动


给黄色方块设置右浮动


 

<head> 
    <style>
        .box{background-color: red;
            height: 200px;
            width: 200px;}
        .box1{background-color: yellow;
            height: 400px;
            width: 400px;
            float: right;} 
    </style>
</head>
<body>
  <div class="box"></div>
  <div class="box1"></div>
</body>

2.png

脱离文档流的特点(元素设置浮动从文档流中脱离以后,元素的一些特点也会发生改变)


块元素:


                    1.不会独占一行


                    2.块元素的宽高被内容撑开


行内元素:


          行内元素脱离文档流会变成块元素,特点与块元素相同


总结:脱离文档流之后不区分块元素和行内元素


4、高度塌陷

在正常的文档流当中,父元素高度是被子元素撑开的


若子元素浮动,脱离文档流,会导致我们父元素高度丢失,我们叫高度塌陷


解决高度塌陷的方法:


1.清除浮动:clear


属性值:


                     none默认值    不清除浮动


                     left   清除左侧元素对当前元素的影响


我们可以在box父元素中,在box1(浮动盒子)后面加一个空盒子(box2)来清除浮动,解决高度塌陷


<head>
    <style>
        .box{border:1px solid red;}
        .box1{background-color: yellow;
             height: 400px;
             width: 400px;
             float:left; 
        .box2{clear:both}
    </style>
</head>
<body>
    <div class="box"><div class="box1"></div>
         <div class="box2"></div>
    </div>
</body>


1.gif

这个方法不太推荐,毕竟加了一个无意义的标签,写一个还行,太多就有点泛滥了


2.给父元素设置固定高度(不建议使用,不够灵活)


3.将父元素添加属性overflow:hidden


缺点:有时候可能会和我们想得到的预期效果不一样


4.给父元素设置一个伪元素选择器,并设置常用的清除浮动的样式,然后after就会把盒子撑开



<head>
    <style>
        .box{border:1px solid red;}
        .box1{background-color: yellow;
            height: 400px;
            width: 400px;
            float:left;}
        .box::after{
            /* 添加一个内容 */
            content:" ";
            /* 将内容转换为块元素 */
            display:block;
            /* 清除两侧的浮动 */
            clear:both;} 
    </style>
</head>
<body>
    <div class="box">
        <div class="box1"></div>
    </div>
</body>

1.gif


 


相关文章
|
2月前
|
前端开发
CSS 浮动属性讲解和使用
本文介绍了CSS中的浮动(float)属性,包括其基本功能、属性选项及其在网页布局中的应用。浮动使元素脱离文档流,向左或右排列,周围元素随之调整。文章还详细讲解了清除浮动的方法,如使用clear属性、设置父元素高度、利用overflow属性、伪元素等,以解决因浮动导致的布局问题。最后,强调了浮动在创建复杂布局时的作用,并预告后续内容。
39 2
|
2月前
|
Web App开发 前端开发 JavaScript
揭秘!前端大牛们如何巧妙利用CSS3,打造炫酷视觉效果!
【10月更文挑战第31天】前端开发面临复杂布局的挑战,本文介绍了几种提升开发效率和代码质量的工具和技术。基础的HTML和CSS可以应对大部分布局需求,而Firefox开发者工具、VS Code、Vue、React等则能应对更复杂的布局,帮助开发者构建高性能、用户友好的网页应用。
35 4
|
3月前
|
前端开发 JavaScript
CSS样式穿透技巧:利用scoped与deep实现前端组件样式隔离与穿透
CSS样式穿透技巧:利用scoped与deep实现前端组件样式隔离与穿透
310 1
|
3月前
|
前端开发 容器
前端技术分享:利用CSS Grid布局实现响应式设计
【10月更文挑战第1天】前端技术分享:利用CSS Grid布局实现响应式设计
|
3月前
|
前端开发 UED 容器
前端技术分享:利用 CSS Grid 实现响应式布局
【10月更文挑战第1天】前端技术分享:利用 CSS Grid 实现响应式布局
82 2
|
3月前
|
前端开发
前端浮动模块
前端浮动模块
26 0
前端浮动模块
|
3月前
|
前端开发 JavaScript 容器
前端之CSS基础知识
前端之CSS基础知识
22 0
|
3月前
|
前端开发 容器
【前端基础篇】CSS基础速通万字介绍(下篇)3
【前端基础篇】CSS基础速通万字介绍(下篇)
23 0
|
3月前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
206 2
|
3月前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
58 0