带你玩透浮动float布局,详解(一)

news2025/1/17 0:50:38

文章目录

  • 一 认识浮动
  • 二 浮动的规则
    • 浮动的规则一
      • 代码展示
    • 浮动规则二
      • 代码展示
    • 浮动规则四
      • 代码展示
      • 代码展示
    • 浮动规则五
  • 空隙的解决方案
      • 代码展示:
        • 第一种方式 放在一行
        • 第二种解决方式(不推荐使用这种方式)
        • 第三种方式采用浮动(推荐,统一向一个方向设置)
        • 第四种方式flex消除(兼容性没有浮动好,如果适配低版本浏览器就不行)
  • 浮动练习一(百度页码)

一 认识浮动

float 属性可以指定一个元素应沿其容器的左侧或右侧放置,允许文本和内联元素环绕它。

float 属性最初只用于在一段文本内浮动图像, 实现文字环绕的效果;

但是早期的CSS标准中并没有提供好的左右布局方案, 因此在一段时间里面它成为网页多列布局的最常用工具;

◼ 绝对定位、浮动都会让元素脱离标准流,以达到灵活布局的效果

◼ 可以通过float属性让元素产生浮动效果,float的常用取值

 none:不浮动,默认值
 left:向左浮动
 right:向右浮动

二 浮动的规则

浮动的规则一

元素一旦浮动后, 脱离标准流

朝着向左或向右方向移动,直到自己的边界紧贴着包含块(一般是父元素)或者其他浮动元素的边界为止

代码展示

// An highlighted block
var foo = 'bar';
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
    .item1, .item2{
        background-color:#f00;
    }
    .item1 {
        float:left;
        background-color: #0f0;
    }
</style>
</head>
<body>
    <div class="item1">1</div>
    <div class="item2">2</div>
</body>
</html>

没有设置float:left属性时
在这里插入图片描述
div元素独占一行
加上float:left属性变为:
在这里插入图片描述
脱离了标准流

如果我增加position等属性,会是什么情况呢?

1
2

运行结果:
在这里插入图片描述
出现这个情况的原因是我设置了position的fixed属性进行了固定,这里想要强调的是浮动元素可以脱离标准流

如果我想要在此基础上使1,2在两边只需要增加:
.item2 {
float: right;
}
在这里插入图片描述
浮动的一个规则特性它是会紧贴父元素
给item外面加入box盒子
并且设置box{
width:100px;
height:100px;
background–colour:orange;
margin:0 auto;
}
运行结果:
在这里插入图片描述

定位元素会层叠在浮动元素上面# 三浮动的案例

浮动规则二

如果元素是向左(右)浮动,浮动元素的左(右)边界不能超出包含块的左(右)边界
带圆圈的数字,标记着浮动元素浮动之前的位置
带圆圈的数字,标记着浮动元素浮动之前的位置

代码展示

1
2
运行结果 ![在这里插入图片描述](https://img-blog.csdnimg.cn/c03133a720cf4c78a6a6cc1ddfc61fbf.jpg) ## 浮动规则三

如果一个元素浮动,另一个浮动元素已经在那个位置了,后浮动的元素将紧贴着前一个浮动元素(左浮找左浮,右浮找右浮)
如果水平方向剩余的空间不够显示浮动元素,浮动元素将向下移动,直到有充足的空间为止

浮动规则四

浮动元素不能与行内级内容层叠,行内级内容将会被浮动元素推出
比如行内级元素、inline-block元素、块级元素的文字内容

代码展示

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
    .item {
        background-color: #f00;
        width: 100px;
        height: 100px;
        float:left;
    }
    .box1 {
        float: left;
        background-color: #0f0;
    }
</style>
</head>
<body>
    <div class="item box1">1</div>
    <div class="item box2">2</div>
    <div class="item box3">3</div>
</body>
</html>

运行结果:
在这里插入图片描述
box1盒子此时已经脱离了标准流,将item里的float取消:
在这里插入图片描述
item1浮动在了左边,其实一在item1的下面
将box1里面设置一个margin–left:10px

运行结果:
在这里插入图片描述
这里更加说明了浮动元素会层叠在普通元素上

注意:这里盒子左上角数字会有一些问题,这个与它的底层渲染原理有关,小编在这里先不讨论了

讲box2设置为float:left
在这里插入图片描述
会发现2盒子紧贴在1盒子后面,说明浮动元素不能与行没级元素进行层叠。

代码展示

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
       <style>    
       .container {       
        width: 375px;        
        height: 300px;        
        background-color: orange; 
           }    
    .item {       
     background-color: #f00;        
     width: 100px;       
      height: 100px;          
       }   
        .box1 {       
         float: left;       
          background-color: #0f0;
          margin-left: 10px;  
            }    
       .box2 {       
        float:left;        
        background-color: yellow;      
           }   
        .box3 {       
         float: left;   
          } 
       .box4 {       
        float: left;       
         background-color: green;   
          }
   </style>
</head>
<body>
   <div class="container">   
      <div class="item box1">1</div>    
      <div class="item box2">2</div>   
      <div class="item box3">3</div>   
      <div class="item box4">4</div>
    </div>   
 </body>
 </html>

运行结果
在这里插入图片描述
如果水平方向剩余的空间不够显示浮动元素,浮动元素将向下移动,直到有充足的空间为止。

浮动规则五

行内非替换元素(文本)与inline–block浮动时 顶部top会默认对齐的。

空隙的解决方案

代码展示:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
    span {
        background-color: orange;
    }
</style>
</head>
<body>
    <div class="box">
        <span>aaa</span>
        <span>bbb</span>
        <span>ccc</span>
    </div>
</body>
</html>

运行结果
在这里插入图片描述

第一种方式 放在一行

这里空隙是怎么产生的?
如果我把三个span标签放到一行会是什么情况呢?
在这里插入图片描述

空隙产生的原因是换行符(不推荐使用这个方式)
那有人就说我写这种代码的时候把它写在一行,不就行了?
这会出现代码的阅读量挺差,如果开发需要写很多复杂的东西你讲代码写成一行,后期也不能很好的去维护!

第二种解决方式(不推荐使用这种方式)

父元素font–size设置为0,子元素font–size必须设置,否则没有任何显示

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style>
.box{
    font-size: 0;
}
    span {
        background-color: orange;
        font-size: 16px;
    }
</style>
</head>
<body>
    <div class="box">
        <span>aaa</span>
        <span>bbb</span>
        <span>ccc</span>
    </div>
</body>
</html>

在这里插入图片描述

第三种方式采用浮动(推荐,统一向一个方向设置)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
    <style>    
    .container {        
      width: 375px;       
     height: 300px;        
     background-color: orange;   
      }    
      .item {      
        background-color: #f00;        
        width: 100px;       
         height: 100px;         
           }    
    .box1 {       
     float: left;       
      background-color: #0f0;
      margin-left: 10px;   
       }   
        .box2 {        
        float:left;      
          background-color: yellow;        0    }    
          .box3 {       
           float: left;   
            }    
           .box4 {       
            float: left;      
         background-color: green;  
         }
   </style>
   </head>
 <body>
    <div class="container">   
        <div class="item box1">1</div>               <div class="item box2">2</div>    
        <div class="item box3">3</div>    <div class="item box4">4</div></div>    </body>
</html>

在这里插入图片描述
如果我想让它们之间有空空隙,设置margin–right就行(而且这种方式特别精准)

第四种方式flex消除(兼容性没有浮动好,如果适配低版本浏览器就不行)

只需要在父元素设置flex即可

.box{
display: flex;
}

浮动练习一(百度页码)

在这里插入图片描述
在这里插入图片描述
运行结果
在这里插入图片描述
由于小编的手机📱开发软件是英文状态,所以最好
后的下一页用拼音写的!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1534125.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

用户中心项目(登录 + 用户管理功能后端)

文章目录 1.登录功能-后端1.思路分析2.完成对用户名和密码的校验1.com/sun/usercenter/service/UserService.java 添加方法2.com/sun/usercenter/service/impl/UserServiceImpl.java 添加方法3.com/sun/usercenter/service/impl/UserServiceImpl.java 新增属性 3.记录用户的登录…

SpringBoot如何写好单元测试

&#x1f413;序言 Spring中的单元测试非常方便&#xff0c;可以很方便地对Spring Bean进行测试&#xff0c;包括Controller、Service和Repository等Spring Bean进行测试&#xff0c;确保它们的功能正常&#xff0c;并且不会因为应用的其他变化而出现问题。 &#x1f413;单元测…

借教室与差分

原题 题目描述 在大学期间&#xff0c;经常需要租借教室。 大到院系举办活动&#xff0c;小到学习小组自习讨论&#xff0c;都需要向学校申请借教室。 教室的大小功能不同&#xff0c;借教室人的身份不同&#xff0c;借教室的手续也不一样。  面对海量租借教室的信息&…

Wmware安装Linux(centerOS、Ubuntu版本)

目录 1、安装wmware 2、center版本 3、ubuntu版本 1、安装wmware 此处不做展开。 2、center版本 需要提前下载的文件&#xff1a; 无图形化界面https://mirrors.aliyun.com/centos/7.9.2009/isos/x86_64/CentOS-7-x86_64-Minimal-2009.iso 有图形化界面https://mirrors.a…

nacos 更新报错“发布失败。请检查参数是否正确”

文章目录 &#x1f50a;博主介绍&#x1f964;本文内容起因解决方案结果 &#x1f4e2;文章总结&#x1f4e5;博主目标 &#x1f50a;博主介绍 &#x1f31f;我是廖志伟&#xff0c;一名Java开发工程师、Java领域优质创作者、CSDN博客专家、51CTO专家博主、阿里云专家博主、清华…

Lenze伦茨8400变频器E84A L-force Drives 操作使用说明

Lenze伦茨8400变频器E84A L-force Drives 操作使用说明

深度强化学习03价值学习

Q*类似于先知&#xff0c;知道动作的后果 价值学习是得到一个近似的价值函数

ubuntu20.04搭建rtmp视频服务

1.安装软件 sudo apt-get install ffmpeg sudo apt-get install nginx sudo apt-get install libnginx-mod-rtmp 2.nginx配置 修改/etc/nginx/nginx.conf文件&#xff0c;在末尾添加&#xff1a; rtmp {server {listen 1935;application live {live on;}} } 3.视频测试 本…

Linux系统Docker安装Drupal并配置数据库实现公网远程访问本地站点

文章目录 前言1. Docker安装Drupal2. 本地局域网访问3 . Linux 安装cpolar4. 配置Drupal公网访问地址5. 公网远程访问Drupal6. 固定Drupal 公网地址 前言 Dupal是一个强大的CMS&#xff0c;适用于各种不同的网站项目&#xff0c;从小型个人博客到大型企业级门户网站。它的学习…

Spring MVC(二)-过滤器与拦截器

过滤器和拦截器在职责和使用场景上存在一些差异。 过滤器 拦截器 作用 对请求进行预处理和后处理。例如过滤请求参数、设置字符编码。 拦截用户请求并进行相应处理。例如权限验证、用户登陆检查等。 工作级别 Servlet容器级别&#xff0c;是Tomcat服务器创建的对象。可以…

Cannot run program “C:\Program Files\Java\jdk-17\bin\java.exe“

错误提示&#xff1a;Cannot run program “C:\Program Files\Java\jdk-17\bin\java.exe” 解决办法&#xff1a; 检查环境变量是否配置是否正确检查项目环境是否正确&#xff0c;可能会出现多个JDK版本&#xff0c;将不需要的删除

Flume入门概述及安装部署

目录 一、Flume概述1.1 Flume定义1.2 Flume基础架构 二、Flume安装部署 一、Flume概述 1.1 Flume定义 Flume是Cloudera提供的一个高可用的&#xff0c;高可靠的&#xff0c;分布式的海量日志采集、聚合和传输的系统。Flume基于流式架构&#xff0c;灵活简单。 1.2 Flume基础…

Nebula Graph-03-NebulaGraph Studio-可视化web工具安装和使用

前言 如果未安装NebulaGraph&#xff0c;可以去看Nebula Graph-01-Nebula Graph简介和安装以及客户端连接 NebulaGraph Studio-可视化web工具安装 1&#xff1a;什么是 NebulaGraph Studio NebulaGraph Studio&#xff08;简称 Studio&#xff09;是一款可以通过 Web 访问的…

一篇文章教会你如何用 Axure 画原型图

原型图对于做出更好的 UI 设计决策非常重要。然而&#xff0c;选择合适的原型工具并不容易。我们需要仔细考虑成本、功能、与其他设计工具的集成、学习曲线、协作功能和用户测试方法&#xff0c;本文将分析 Axure 的原型设计工具。 1、为何使用 Axure 绘制原型图&#xff1f; …

【喜讯】同邦集团正式成为广州数据交易所会员!高效开展数据管理。

近日&#xff0c;同邦信息科技顺利通过广州数据交易所数商会员资格审查&#xff0c;正式加入广州数据交易所数商生态。 据悉&#xff0c;2022年9月&#xff0c;广州数据交易所正式挂牌成立。广州数据交易所采用“一所多基地多平台”的体系架构进行运营&#xff0c;探索在条件成…

CSA发布| 科技创新和云计算趋势中的网络安全因素

关注国际云安全联盟公众号&#xff0c;回复关键词 “云安全”&#xff0c;即可获取报告完整版 随着云计算的高速发展&#xff0c;如何在云环境中保障数据和应用的安全性日益成为企业共同的关注点&#xff0c;企业也正在考虑多云和混合云策略。云原生技术如容器、微服务和无服务…

Docker 中 Nginx 反向代理

本文主角&#xff1a;Nginx Proxy Manager 。 使用docker安装Nginx Proxy Manager。 1、找到C:\Windows\System32\drivers\etc下的hosts文件&#xff0c;添加 “域名 IP"即可。 使用vscode编辑文件&#xff0c;保存时会提示用管理员权限保存即可。 2、Nginx Proxy Mana…

jupyter | jupyter C++开发环境构建

搭建环境 按照 https://root.cern.ch/cling-build-instructions 官网的提示&#xff0c;手动编译Cling编译器,分别检查llvm&#xff0c;clang和cling&#xff1a; mkdir /path/to/cling cd /path/to/cling git clone http://root.cern.ch/git/llvm.gitcd llvm git checkout c…

金蝶云星空——单据附件上传

文章目录 概要技术要点代码实现小结 概要 单据附件上传 技术要点 单据附件上传金蝶是有提供标准的上传接口&#xff1a; http://[IP]/K3Cloud/Kingdee.BOS.WebApi.ServicesStub.DynamicFormService.AttachmentUpLoad.common.kdsvc 参数说明 参数类型必填说明FileName字符是…

spring boot 输出日志保存到文件

spring boot 和 spring cloud 的模块,都已经引入了Logback作为其日志框架. 只需要配置 logback.xml 文件就可以实现保存日志到文件 文件内容为 <?xml version"1.0" encoding"UTF-8"?> <configuration scan"true" scanPeriod"6…