奇怪的float
我在项目的实践中遇到了这样的一个问题
<div class="main">
<p>aaaa</p>
<p>bbbb</p>
</div>
* {
padding: 0;
margin:0;
}
p {
padding-left: 30px;
}
.main {
background: green;
}
上面的效果是这样的

我想让父元素div 里面的两个p元素通过float到同一行
我添加了这样一句话
.main p {
float:left;
}
我理所应当 异想天开的以为会是这样的结果

结果是这个样子的

为了更好的说明这个问题,也是我刚在疑惑的地方 我又将页面父div下面增加了一个div
<div class="main">
<p>aaaa</p>
<p>bbbb</p>
</div>
<div>cccc</div>
也就是我总体的想实现是这样的一个布局

结果我通过上面的那一点css 是这样的一个效果

我在实际遇到这个问题是在上面那个父div并没有设置背景色 我通过审查元素看到那个div的高度变成0了 我也不是很明白为什么下面的div会挤上去 应为两个div是块级元素,不会向上浮动的
原来float会造成一个塌陷的问题 当我们没有为父元素设置高度的时候 ,并且父元素只包含浮动元素的时候 就会产生塌陷这种问题 父元素无法通过布局的方式获得高度,所以高度为0
2016 8 13 关于布局的一些学习 参考 浏览器工作原理
在进行布局的时候,浏览器采用一种dirty位系统,如果某个呈现器(需要渲染布局的元素)发生了更改,将其自身或者子代标记为dirty,则需要布局,在进行布局的时候,元素会确认自己宽度和高度
布局模式:
(1)父呈现器确认自己的宽度
(2)父呈现器依次处理子呈现器
2.1 放置子呈现器(设置x y 坐标)
2.2 如果有必要,调用子呈现器的布局
(3)父呈现器根据子呈现器的累加高度以及边距和补白的高度来设置自身高度,此值也可供父呈现器的父呈现器使用
(4)将dirty设置为false
解决方案:清除浮动:
2016 6 23
为了防止内容流过浮动元素 比如你不希望一个元素的左边是浮动元素 就可以通过clear:left来实现
1)加一个空的div
<div style="clear:both;"></div>
2016 8 22 clear的工作原理 在
2)可以为父元素设置overflow:hidden; zoom :1
这样的情况下父元素就会自动扩展来包含他里面的浮动元素了,并且下面的div也自动的到下面去了(之所以这样的设置是因为让父元素表现的更像一个容器生成了一个BFC,会扩展 包裹性) zoom属性是按比例缩放的 zoom:1 按原始比例缩放 父元素就会包裹子元素 IE下触发了Layout
3)还有一种方法是在需要清除浮动元素之后通过css伪类:after添加一个不可见的内容 在它的上面clear:both
2016.3.17 刚看到大漠老师翻译的一篇文章 把伪类的清除浮动的方案优化下 成如下的形式
.main::after,.main::before {
content:'';
display:table;
clear:both;
}
这就是我解决浮动这个问题的学习过程 拿来分享
2016 5 19 在面试中被问到BFC,在学习的过程中发现BFC中有一条规则就是在计算BFC的高度的时候,浮动元素也会被计算在内 这就说明了在包含浮动元素的父元素中设置overflow:hidden 生成BFC去包裹浮动元素的原理
2016 6 23 更新一些关于float的一些原理的东西 CSS权威指南 css脱离文档流 知乎上的回答 关于CSS中浮动元素脱离普通流问题
浮动是一种脱离文档流,对之后或者之前的盒子中的content flow产生影响的一个属性(区别于定位 例如position absolute 也是脱离文档流 但是它不会对之后之前的盒子产生影响)
首先浮动元素会生成一个块级框 即使它本身是一个行内元素
规则:
1) 浮动元素的左右外边界不能超出其包含块的左右内边界
2)浮动元素的左(或右)外边界必须是源文档中之前出现的左浮动的(或右浮动)元素的右(或左)边界,除非后出现的浮动元素的顶端在先出现浮动元素的底端下面(防止浮动元素之间的覆盖)
3)左浮动元素的右外边界不会在其右边右浮动元素的左外边界的右边 右浮动元素的左外边界不会在其左边左浮动元素的右外边界的左边
4)一个浮动元素的顶端不能比其父元素的内顶端更高 浮动元素的顶端不能比之前所有的浮动元素的顶端或块级元素更高

上面的例子中三个元素均为浮动元素 由于规则3的作用 第二个元素不能跟第一个元素占据同一行(包含块宽度的限制) 我们看到第三个元素的顶端跟第二个元素的顶端一样
5)如果源文档中一个浮动元素之前出现了另一个元素 浮动元素的顶端不能比包含该元素所生成框的任何行框的顶端更高
6) 左浮动元素必须向左尽可能的远 右浮动元素必须向右尽可能的远 位置越高 就会向左或者向右尽可能的远
上面是浮动的一些规则 下面说一下行为
(1)当父元素是定高的时候 里面的浮动元素的高度超出了父元素的高度

上面的例子中浮动元素的高度就超出了父元素的高度 之前的规则只进行了浮动元素的上 左右与包含块的边界的限制 在权威指南上说浮动会延伸,也就是在超出高度的浮动元素的包含块上也设置浮动 让它去包裹父元素 其实这是一种生成BFC的模式 BFC在计算高度的时候会包含浮动元素的高度 所以父元素会扩展
关于BFC的: BFC神奇背后的原理 请移步这位园友的blog 看了很多遍
(2)负外边距
通过设置浮动元素的负外边界可以实现浮动元素的外边界超出包含块外边界的情况(不要采取这种模式) 无法得知浏览器的预期行为
(3)浮动元素与正常内容流重叠的情况
行内框与一个浮动元素重叠的时候,其边框 背景 和内容都在该浮动元素之上显示
块框与一个浮动元素重叠时候 其边框和背景在该浮动之下显示 内容在浮动元素之上显示
奇怪的float的更多相关文章
- Shadertoy 教程 Part 5 - 运用SDF绘制出更多的2D图形
Note: This series blog was translated from Nathan Vaughn's Shaders Language Tutorial and has been au ...
- js实现省市区联动
先来看看效果图吧,嘻嘻~~~~~~~~~~~~~~~~~~~· 代码在下面: 示例一: html: <!DOCTYPE html> <html> <head> &l ...
- CSS Float浮动所带来的奇怪现象
先抛个例子出来 运行下面的例子后,可以看到输出内容如下. <!DOCTYPE html> <html lang="en"> <head> < ...
- float浮点数的二进制存储方式及转换
int和float都是4字节32位表示形式.为什么float的范围大于int? float精度为6-7位.1.66*10^10的数字结果并不是166 0000 0000 指数越大,误差越大. 这些问题 ...
- float和double的精度
作者: jillzhang 联系方式:jillzhang@126.com 原网址:http://blog.csdn.net/wuna66320/article/details/1691734 1 范围 ...
- Java浮点数float,bigdecimal和double精确计算的精度误差问题总结
(转)Java浮点数float,bigdecimal和double精确计算的精度误差问题总结 1.float整数计算误差 案例:会员积分字段采用float类型,导致计算会员积分时,7位整数的数据计算结 ...
- css知多少(8)——float上篇
1. 引言 对于我们所有的web前端开发人员,float是或者曾经一度是你最熟悉的陌生人——你离不开它,却整天承受着它所带给你的各种痛苦,你以为它很简单就那么一点知识,但却驾驭不了它各种奇怪的现象. ...
- CSS浮动属性Float介绍
#cnblogs_post_body h6 {font-size: 16px;font-weight: bold;} 什么是CSS Float? float 是 css 的定位属性.在传统的印刷布局中 ...
- decimal,float和double的区别
http://www.cnblogs.com/yellowapplemylove/archive/2011/08/23/2150316.html 一直很奇怪C#的预定义数据类型中为什么加了一个deci ...
随机推荐
- 自动SPF生成工具
到openspf网站去自动生成一下,地址是http://old.openspf.org/wizard.html.详细解释见下图关于spf的详细语法请看http://www.openspf.org/SP ...
- ios面试技术要点
iOS面试 技术总结点(可参考):多线程 运行时 runloop app框架 几种动画编程 jsonmodel原理 sdwebimage原理 masonry怎么应用及原理 应用框架有哪些 说一下Fac ...
- IIS7/IIS7.5 二级域名伪静态设置方法
转载地址:http://www.admin5.com/article/20120107/402582.shtml
- CLR via C#深解笔记一 - CLR & C# 基础概念
写在前言 .Net Framework并不是Win 32 API 和COM上的一个抽象层. 某种程度上,它是自己的操作系统,有自己的内存管理器,自己的安全系统,自己的文件加载器,自己的错误处理 ...
- 十九、【.Net开源】EFW框架核心类库之WCF控制器
回<[开源]EFW框架系列文章索引> EFW框架源代码下载V1.1:http://pan.baidu.com/s/1qWJjo3U EFW框架实例源代码下载:http://pan.baid ...
- 让我们一起Go(十二)
前言: 上篇中,我们讲到了在Go语言中如何定义方法,今天,我们将进一步深入Go语言的面向对象编程. 一.Go语言中的接口 首先来看一个最基本的接口: 和定义一个结构体类似,只不过将struct换成了i ...
- PIN码计算锦集
1. 腾达,C8:3A:35开头的MAC有效~network路由,MAC有效~以及00B00C开头的MAC有效之外的请您自己发现算法..这里只公布三个MAC地址算法,其余也可以算~这里就不公布出来了. ...
- 支付SDK的安全问题——隐式意图可导致钓鱼攻击
该漏洞涉及到app所使用的intent和intent filter. intent是一个可用于从一个app组件请求动作或处理事件的“消息对象”.Intent负责对应用中一次操作的动作.动作涉及数据. ...
- Maven进价:Maven构建系列文章
Maven:基于Java平台的项目构建.依赖管理和项目信息管理. 1.构建 Maven标准化了构建过程 构建过程:编译.运行单元测试.生成文档.打包和部署 避免重复:设计.编码.文档.构建 2.依赖管 ...
- ruby -- 进阶学习(十四)设置background-image(解决无法获取图片路径问题)
基于rails4.0环境 为了美化界面,添加背景图片,于是又傻逼了一回~~ 一开始在xxx.html.erb中添加:(注:图片的路径为:app/asssets/images/background.jp ...