热门标签 | 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即可,如下右图


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


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



推荐阅读
  • Appium + Java 自动化测试中处理页面空白区域点击问题
    在进行移动应用自动化测试时,有时会遇到某些页面没有返回按钮,只能通过点击空白区域返回的情况。本文将探讨如何在Appium + Java环境中有效解决此类问题,并提供详细的解决方案。 ... [详细]
  • 利用Selenium与ChromeDriver实现豆瓣网页全屏截图
    本文介绍了一种使用Selenium和ChromeDriver结合Python代码,轻松实现对豆瓣网站进行完整页面截图的方法。该方法不仅简单易行,而且解决了新版Selenium不再支持PhantomJS的问题。 ... [详细]
  • 本文介绍了如何使用JavaScript的Fetch API与Express服务器进行交互,涵盖了GET、POST、PUT和DELETE请求的实现,并展示了如何处理JSON响应。 ... [详细]
  • 本文详细介绍如何使用 HTML5 和 JavaScript 实现一个交互式的画板功能。通过具体代码示例,帮助读者理解 Canvas API 的基本用法及其在绘图应用中的实际应用。 ... [详细]
  • 探讨 HDU 1536 题目,即 S-Nim 游戏的博弈策略。通过 SG 函数分析游戏胜负的关键,并介绍如何编程实现解决方案。 ... [详细]
  • CSS高级技巧:动态高亮当前页面导航
    本文介绍了如何使用CSS实现网站导航栏中当前页面的高亮显示,提升用户体验。通过为每个页面的body元素添加特定ID,并结合导航项的类名,可以轻松实现这一功能。 ... [详细]
  • 本文详细介绍了如何在Kendo UI for jQuery的数据管理组件中,将行标题字段呈现为锚点(即可点击链接),帮助开发人员更高效地实现这一功能。通过具体的代码示例和解释,即使是新手也能轻松掌握。 ... [详细]
  • 在尝试使用C# Windows Forms客户端通过SignalR连接到ASP.NET服务器时,遇到了内部服务器错误(500)。本文将详细探讨问题的原因及解决方案。 ... [详细]
  • 深入解析动态代理模式:23种设计模式之三
    在设计模式中,动态代理模式是应用最为广泛的一种代理模式。它允许我们在运行时动态创建代理对象,并在调用方法时进行增强处理。本文将详细介绍动态代理的实现机制及其应用场景。 ... [详细]
  • 通常情况下,修改my.cnf配置文件后需要重启MySQL服务才能使新参数生效。然而,通过特定命令可以在不重启服务的情况下实现配置的即时更新。本文将详细介绍如何在线调整MySQL配置,并验证其有效性。 ... [详细]
  • 深入解析ESFramework中的AgileTcp组件
    本文详细介绍了ESFramework框架中AgileTcp组件的设计与实现。AgileTcp是ESFramework提供的ITcp接口的高效实现,旨在优化TCP通信的性能和结构清晰度。 ... [详细]
  • 本文探讨了在 SQL Server 中使用 JDBC 插入数据时遇到的问题。通过详细分析代码和数据库配置,提供了解决方案并解释了潜在的原因。 ... [详细]
  • 本文详细比较了CSS选择器和XPath在Selenium中通过页面结构定位元素的优劣,并提供了具体的代码示例,帮助读者理解两者在不同场景下的适用性。 ... [详细]
  • 本题要求在一组数中反复取出两个数相加,并将结果放回数组中,最终求出最小的总加法代价。这是一个经典的哈夫曼编码问题,利用贪心算法可以有效地解决。 ... [详细]
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
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社区 版权所有