1、span、a、input、select等。示例代码:复制代码代码如下:span style=float: left; 150px; height: margin: 5px; padding:border: solid 1px red; background-color: Olive;浮动元素span/divwidth: border:background-color:效果如下:二、浮动元素后的非浮动元素问题 浮动元素后边的元素若是非浮动行内元素且因为定位产生重叠时,行内元素边框、背景和内容都在该浮动元素“之上”显示,若是非浮动块级元素跟在浮动元素后边且在定位后产生重叠时,该块级元素边框和背景在
2、该浮动元素“之下”显示,只有内容在浮动元素不在浮动元素“之下”显示。示例代码如下: 600px; 500px; solid 1px blue; yellow; 250px; solid 1px Aqua; gray;margin: 10px 0 0 10px;浮动DIV red; solid 1px green; 300px;跟在浮动元素后边的DIV 0 0 0 -50px;跟在浮动元素后边的span效果图如下:从图中可以看出来,跟在浮动div后边的div背景以及边框被压在了底下,内容却没有,span整体都在浮动div之上显示。不过在ie6这个效果却很怪异,如图:浮动元素没有压在非浮动div之
3、上,反而把span压住了。三、多个并列同方向浮动元素高度不一致问题多个同方向浮动元素若是高度不一致的话,很可能会得到意外的效果,跟你想要的布局差别很大。多个同方向浮动元素一般是按照流式布局,一行满了则自动换行,也就是类似于以下效果:但各个浮动元素高度不一致的话效果很可能出现下边的情况:很意外吧,主要排列到元素7的时候,一行已经显示不下了,所以要换行,但此处换行并不是从行头开始,而是从元素5那开始,因为元素5比元素6高很多导致。四、子元素全为浮动元素高度自适应问题由于元素浮动后脱离了文档流,所以父元素是无法根据元素来自适应的。解决此问题最常用的办法由两种,第一种就是在所有浮动元素后加:clear
4、:both;0px;第二种办法,使用万能clear:.clearfix:after visibility: hidden;display: block;font-size: 0;content: .; both; * html .clearfixzoom: 1;*:first-child + html .clearfix然后在你需要自适应的元素上加上class=”clearfix”即可。详细请参考:你真的理解clear:both吗在开发中,从美工MM给你Html代码中,肯定能经常看”这样的代码,但是你真的能明白它是做什么用的吗?如:1px solid red;left;80px;1px sol
5、id blue;TEST DIV你可以将此部分代码放到一个HTML页面看看效果,然后在去掉”after * html .clearfixzoom:first-child + html .clearfixzoom:/stylediv class=clearfix style= 1px solid red; 80px; 1px solid blue;看完解决办法,咱们来看里边的原理:(1)、首先是利用:after这个伪类来兼容FF、Chrome等支持标准的浏览器。:after伪类IE不支持,它用来和content属性一起使用设置在对象后的内容,例如:a:aftercontent:(link)这个CSS将会让a标签内的文本后边加上link文本文字。(2)、利用“* html”这个只有IE6认识的选择符,设置缩放属性“zoom:”实现兼容IE6。(3)、利用“*:first-child + html”这个只有IE7认识的选择符,设置缩放属性“zoom:”实现兼容IE7。
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1