你的位置:面向PHP >> 资讯 >> 前端开发 >> 前端优化、架构 >> 详细内容 在线投稿

CSS浮动属性Float详解

热度241票  浏览92次 【共0条评论】【我要评论 时间:2009年9月10日 21:54
文章信息

来源:转载

什么是CSS Float?

面向PHP&Q5^ ] u(R

float 是 css 的定位属性。在传统的印刷布局中,文本可以按照需要围绕图片。一般把这种方式称为“文本环绕”。在网页设计中,应用了CSS的float属性的页面元素就像在印刷布局里面的被文字包围的图片一样。浮动的元素仍然是网页流的一部分。这与使用绝对定位的页面元素相比是一个明显的不同。绝对定位的页面元素被从网页流里面移除了,就像印刷布局里面的文本框被设置为无视页面环绕一样。绝对定位的元素不会影响其它元素,其它元素也不会影响它,无论它是否和其它元素挨着。

l H_"F,p P?xx0面向PHP v2Zi8~0J%t HWN

像这样在一个元素上用CSS设置浮动:面向PHPN7oK {.k(uE

#sidebar { float: right; }
面向PHP1thC%v%Yq7n N1|

fload属性有四个可用的值:Left 和Right 分别浮动元素到各自的方向,None (默认的) 使元素不浮动,Inherit 将会从父级元素获取float值。

{in2[W0

Float的用处

面向PHPt5Pl{7Yr{l @

除了简单的在图片周围包围文字,浮动可用于创建全部网页布局。面向PHPE$V Lk4Jfx*@$VF z

面向PHP&H%b bp.J0V[N*@)B

web layout CSS浮动属性Float详解

aQLQ2@ Q3\i0面向PHP3W-^.C.E!q tj

Float对小型的布局同样有用。例如页面中的这个小区域。如果我们在我们的小头像图片上使用Float,当调整图片大小的时候,盒子里面的文字也将自动调整位置:

?$j8v0qX0面向PHPc b6j{P

reflow example 1 CSS浮动属性Float详解面向PHP@|4QTh*L(a

面向PHP(Z"W{~ Fm J_/t!K

同样的布局可以通过在外容器使用相对定位,然后在头像上使用绝对定位来实现。这种方式中,文本不会受头像图片大小的影响,不会随头像图片的大小而有相应变化。

#vV KzP"g l0

*O ?Xn V*F0reflow example 2 CSS浮动属性Float详解面向PHP*qL2C~_Ch

清除Float

,Q!ET{0w0清除(clear)是浮动(float)的相关属性.一个设置了清除Float的元素不会如浮动所设置的一样,向上移动到Float元素的边界,而是会忽视浮动向下移动。如下,一图顶千言。面向PHP@xJY2A

D5{z|JL6y0uncleardfooter

'pcMC9tf'aX"T0

X"X~6[#eL0上例中,侧栏向右浮动,并且短于主内容区域。页脚(footer)于是按浮动所要求的向上跳到了可能的空间。要解决这个问题,可以在页脚(footer)上清除浮动,以使页脚(footer)待在浮动元素的下面。

VC2op7WB\0
#footer { clear: both; }

T9K K]&S*B.A0cleardfooter面向PHP;I(D.^ a;U2F] tm

面向PHPn;o bh5]

清除(clear)也有4个可能值。最常用的是 both,清楚左右两边的浮动。left 和 right 只能清楚一个方向的浮动。none是默认值,只在需要移除已指定的清除值时用到。inherit 应该时第五个值,不过很奇怪的是 IE 不支持(这个不奇怪吧,IE从来都这么特立独行吧 -糖伴西红柿注)。只清除左边或右边的浮动,实际中很少见,不过绝对有他们的用处。面向PHPd1w H3[MB4e.KA{

!_B[iLr/j`!l0directionalclearing CSS浮动属性Float详解

RKP {&K0

伟大的塌陷

4F \ P z1A7V0使用浮动(float)的一个比较疑惑的事情是他们怎么影响包含他们的父元素的。如果父元素只包含浮动元素,那么它的高度就会塌缩为零。如果父元素不包含任何的可见背景,这个问题会很难被注意到,但是这是一个很重要的问题。

V:oRFY6y0面向PHPY)o6y2^+e%IS)r1N k

collapse CSS浮动属性Float详解面向PHP5~_?5w6Z@

jq;e1P*^KQl0塌陷的直观对立面更不好,看看下面的情况:

$g;c#Jmf0\7\5tH0

$yg1_%ih0whywecollapse CSS浮动属性Float详解面向PHP.z;W/zJ jb jGF

面向PHP;z-_$k8rh(f"O

当上面的块级元素自动扩展以适应浮动元素时,段落间的文本流中会出现非自然的空白换行,而且没有有效的方法来修正这个问题。对于这种情况,设计师的抱怨会更甚于对塌陷的抱怨(没理解,不是设计完成之后才会进行页面编码吗?- 糖伴西红柿)。

yA3q1yv0

XU'^ @!Of9@a0为了防止怪异的布局和跨浏览器的问题,塌陷问题几乎总是被要处理的。我们在容器中的浮动元素之后,容器结束之前来清除浮动。面向PHP3x\[$}F

清除浮动的技术

面向PHP4g|q5}4T`4h L8KU

如果你很明确的知道接下来的元素会是什么,可以使用 clear:both; 来清除浮动。这个方法很不错,它不需要 hack,不添加额外的元素也使得它有良好的语义性。当然事情并不是都可以这样解决的,工具箱中还是需要另外几个清除浮动的工具。

*w.zL dZJ"o{5X0
  • 空div方法从字面来看,是一个空的 div。
    "p9C9f;B)tl[`0。有时可能会用
    mJk:z~n ^7V0或者一些其他元素,但是 div 是最常用的,因为它没有浏览器默认样式;没有特殊功能,而且一般不会被 css 样式化。这个方法因为只是为了表现,对页面没有上下文涵义而被纯语义论者嘲笑。诚然,从严格的角度来说他们是对的,但是这个方法有效而且没有任何伤害。
  • overflow 方法在父元素上设置 overflow 这个 css属性。如果父元素的这个属性设置为 auto 或者hidden,父元素就会扩展以包含浮动。这个方法有着较好的语义性,因为他不需要额外元素。但是,如果需要增加一个新的 div来使用这个方法,其实就和空 div 方法一样没有语义了。而且要记住,overflow属性不是为了清除浮动而定义的。要小心不要覆盖住内容或者触发了不需要的滚动条。
  • 简单清除方法使用了一个聪明的 css 伪选择符(:after)来清除浮动。比起在父元素上设置 overflow,只需要给它增加一个额外的类似于”clearfix”的类。这个类使用如下 css:
    			.clearfix:after {面向PHPgF!NM+N9r?D|
    content: ".";面向PHP/C'Kbz f&J|TN
    visibility: hidden;
    0~(i B8bU`p0 display: block;
    G1ifa QBt s(DO ya0 height: 0;面向PHPP-Sh,Z |-jPimH
    clear: both;
    B4\,R4mDBg)e0 }
    面向PHP#Q%b7w*iN8n

    这会在清除浮动的父元素之后应用一点看不见的内容。这不是全部内容,还需要一些额外的代码来适应那些老旧的浏览器。面向PHP Va;Vg*~ H _!u

Z.[T c&P:A@0不同的情况需要不同的浮动清除方法。以一个具有不同样式块的网格为例。

M'GP`c g*l \0面向PHPVy'P)Z.n

grid blocks CSS浮动属性Float详解

+C?P6gn_'QU#JK0面向PHP`;f L(ZpV0D7m4Q(u0l

为了从视觉上较好的把相似的块联系起来,需要在必要的地方开启新行,这里是颜色改变的地方。如果每个颜色组都有一个父元素的话,我们可以使用overflow 或者 简单清除方法。或者,在每组之间用一个空div方法。额外的 div 之前并不存在,可以自己试试来看看哪个方法好。

x d4e1n-_V5i0

)_-P)too~m$x6Y0grid blocks cleared CSS浮动属性Float详解面向PHPZ4kT-sH_ Zw

浮动的问题

面向PHP k;P@$z)|5}#~

浮动因脆弱而饱受诟病。大多数的脆弱性来自于 IE6 及其一系列的浮动相关 bug。因为越来越多的设计师不再支持 IE6 了,你也可以不关注它了。不过对于那些要关注的人来说,这里有些大概。

9zSW-a(lW}Y-emF0
  • 推倒是浮动元素内的元素(大多是图片)比浮动元素本身宽造成的现象。大多数的浏览器会在浮动之外渲染图片,但是不会有伸出来的部分影响其他布局。IE 会扩展浮动来包含图片,精彩大幅度地影响布局。一个普遍的例子是突破伸出主内容之外把侧栏推到下面。pushdown2 CSS浮动属性Float详解
  • 快速修正:确保不是图片造成这种情况,使用 overflow:hidden 来切除多余的部分。
  • 双倍边距bug处理 IE6 时,另一个需要记住的事情是,如果在和浮动方向相同的方向上设置外边距(margin),会引发双倍边距。快速修正:给浮动设置 display:inline; 而且不用担心,它依然是块级元素。
  • 3像素间距是指挨着浮动元素的文本会神奇的被踢出去3像素,好像浮动元素的周围有一个奇怪的力场一样。快速修正:在受影响的文本上设置宽度或高度。
  • IE7 中,底边距 bug是当浮动父元素有浮动子元素时,这些子元素的底边距会被父元素忽略掉。快速修正:用父元素的底内补白(padding)代替。

5I:e'a+WE8?0英文原文:all about floats面向PHP Qzj%E%`9BR
中文译文:关于浮动的前世今生

7i6u7}\!VX:F0
TAG: CSS css 属性 详解 Float
顶:17 踩:13
对本文中的事件或人物打分:
当前平均分:-0.49 (69次打分)
对本篇资讯内容的质量打分:
当前平均分:-0.38 (78次打分)
【已经有64人表态】
8票
感动
8票
路过
8票
高兴
6票
难过
7票
搞笑
7票
愤怒
11票
无聊
9票
同情
上一篇 下一篇
发表评论

网友评论仅供网友表达个人看法,并不表明本网同意其观点或证实其描述。

查看全部回复【已有0位网友发表了看法】