热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

CSS专题之浮动

一提到浮动,可能大家都懂,但是你有没有一种感觉,在自己独立进行布局时,有时候总感觉哪里不对劲,又不知道到底是哪

一提到浮动,可能大家都懂,但是你有没有一种感觉,在自己独立进行布局时,有时候总感觉哪里不对劲,又不知道到底是哪儿不对劲,其实很多时候就是浮动并没有完全搞清楚,希望这篇文章能助你理清浮动的知识。

基本知识就不多说了,以下用一个例子来说明浮动,搞懂这个就差不多了

问题描述 

若想实现如下所示布局,该如何做?


HTML结构大致如下(section1200px,40%,section2100px,宽50%):

头部

section1 float:left;
section2 float:left;
尾部

步骤1:设置section1左浮动,大致出现下图:


仔细观察,section1虽然脱离文档流,但仍然占据了section2和尾部的位置,导致内容被挤压,注意此时设置section2margin-left:40%可得到如下效果:


步骤2:清楚浮动

 .clearfix:after {content:""; display:block; height:0; visibility:hidden; clear:both; }

}

.clearfix { *zoom:1; }

wrapper添加clearfix类,得到如下完成效果


问题注意:

父元素中有子元素时,且子元素都没设置浮动,则父元素高度由子元素高度叠加,若其中有子元素设置了浮动,则该元素脱离文档流,计算父元素高度时与它无关,但其内容还是占地方。

 

父元素中若有子元素设置了浮动,则没有设置浮动的子元素的margin-top会失效(浮动元素的不会失效),这里的失效是指margin-top不针对父元素了,而是针对父元素的上一个兄弟元素(当没有兄弟元素时,针对浏览器),如下图左:child3设置了margin-top:20px,但针对的不是父元素。若实在需要child3下移,可通过将父元素设置padding-top:20px即可,如下右图


浮动布局时,最好将需要浮动的元素用一个父元素包起来。子元素设置浮动,父元素清除浮动。


有需要源码的可在下方留言哈~



推荐阅读
  • 本文介绍了SIP(Session Initiation Protocol,会话发起协议)的基本概念、功能、消息格式及其实现机制。SIP是一种在IP网络上用于建立、管理和终止多媒体通信会话的应用层协议。 ... [详细]
  • 本文详细介绍了在Windows系统中如何配置Nginx以实现高效的缓存加速功能,包括关键的配置文件设置和示例代码。 ... [详细]
  • 深入理解:AJAX学习指南
    本文详细探讨了AJAX的基本概念、工作原理及其在现代Web开发中的应用,旨在为初学者提供全面的学习资料。 ... [详细]
  • 在1995年,Simon Plouffe 发现了一种特殊的求和方法来表示某些常数。两年后,Bailey 和 Borwein 在他们的论文中发表了这一发现,这种方法被命名为 Bailey-Borwein-Plouffe (BBP) 公式。该问题要求计算圆周率 π 的第 n 个十六进制数字。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • Requests库的基本使用方法
    本文介绍了Python中Requests库的基础用法,包括如何安装、GET和POST请求的实现、如何处理Cookies和Headers,以及如何解析JSON响应。相比urllib库,Requests库提供了更为简洁高效的接口来处理HTTP请求。 ... [详细]
  • Windows操作系统提供了Encrypting File System (EFS)作为内置的数据加密工具,特别适用于对NTFS分区上的文件和文件夹进行加密处理。本文将详细介绍如何使用EFS加密文件夹,以及加密过程中的注意事项。 ... [详细]
  • 如何在PHP中安装Xdebug扩展
    本文介绍了如何从PECL下载并编译安装Xdebug扩展,以及如何配置PHP和PHPStorm以启用调试功能。 ... [详细]
  • importjava.io.*;importjava.util.*;publicclass五子棋游戏{staticintm1;staticintn1;staticfinalintS ... [详细]
  • 本文详细介绍了如何利用 Bootstrap Table 实现数据展示与操作,包括数据加载、表格配置及前后端交互等关键步骤。 ... [详细]
  • 解决Visual Studio Code中PHP Intelephense误报问题
    PHP作为一种高度灵活的编程语言,其代码结构可能导致Intelephense插件在某些情况下报告不必要的错误或警告。自1.3.3版本起,Intelephense引入了多个配置选项,允许用户根据具体的工作环境和编程风格调整这些诊断信息的显示。 ... [详细]
  • HTML:  将文件拖拽到此区域 ... [详细]
  • 本文详细探讨了在Web开发中常见的UTF-8编码问题及其解决方案,包括HTML页面、PHP脚本、MySQL数据库以及JavaScript和Flash应用中的乱码问题。 ... [详细]
  • 本文介绍了如何通过 XMLHttpRequest 对象在不同浏览器中实现 AJAX 的 POST 和 GET 请求,并详细说明了 XMLHttpRequest 的五个状态及其含义。 ... [详细]
  • 在现代Web开发中,HTML5 Canvas常用于图像处理和绘图任务。本文将详细介绍如何将Canvas中的图像导出并上传至服务器,适用于拼图、图片编辑等场景。 ... [详细]
author-avatar
小白一枚
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有