clearfix 清除浮动的问题
今天看一篇博文,发现其实有很多方法实现清除浮动,各有利弊
- 采用伪类:after进行后续空制的高度位零的伪类层清除
- 采用CSS overflow:auto的方式撑高
- 采用CSS overflow:hidden的方式产生怪异适应
- 采用display:table将对象变成table形式
- 采用div标签,以及css的clear属性
- 采用br标签,以及css的clear属性
- 采用br标签,以及其自身HTML的clear属性
粗略的看,他们都能将问题解决;然而他们另外一方面又有着各自的利弊。(一一对应)
- 优点结构语义化完全正确,不会产生其余的怪异问题。 缺点复用方式不当容易造成代码量急剧增大。 建议最外层轻浮动时使用,或清晰模块化复用方式的人使用。
- 优点结构语义化完全正确,代码量极少。 缺点多个嵌套后,点击最外层的轻浮动框会遭成最外层至最内层内容全选(FF);或者在mouseover造成宽度改变时会出现最外层模块有滚动条(IE)。 建议内个模块使用,请勿嵌套。
- 优点结构语义化完全正确,代码量极少。 缺点内容增多时候极易不会自动换行而内容被隐藏掉。 建议宽度固定时使用,请勿嵌套。
- 优点结构语义化完全正确,代码量极少。 缺点盒模型属性已经改变,可想而知奇异事件自然多得你数都数不到。 建议如果你不想改Bug改死你的话,最好不要使用;不过可以作为alpha版本当中临时性的忽悠下测试。
- 优点代码量极少,复用性极高。 缺点完全不能完美的适应语义化,不利于改版以及需求变更。 建议初学者使用,可以让你快速的解决浮动问题。
- 优点语义化程度比第5种情况要更优;代码量极少,复用性极高。 缺点语义化依旧不完美,不利于改版以及需求变更。 建议初学者使用,可以让你快速的解决浮动问题。
- 优点语义化程度比第5、6种情况要更优;代码量最少,复用性极高。 缺点语义化依旧不完美,不利于改版以及需求变更。 建议引导初学者思维升级时使用,让其明白与其用classname来控制一种表现,倒不如回归到WEB1.0的时代的网页直接用html属性来控制表现,毕竟后者的代码量更少。
最后,列举完毕。然而我想有必要和大家道歉,关于之前转载鬼的那篇文章;非常后悔的是当初改了鬼的标题将“最简单”改成了“最优”,以致于后面误导了很多的同学。所以重新写了一篇给大家分享。
整理一下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>清楚浮动</title>
<style>
*{padding:0px; margin:0px;}
ul{border:3px solid #396; margin-bottom:10px;}
ul li{width:50px; height:50px; float:left; border:1px solid #00F; list-style:none; margin-right:10px;} /*
--------------------------------------------- 采用伪类:after进行后续空制的高度位零的伪类层清除
---------------------------------------------
*/
.clearfix_after{zoom:1;}
.clearfix_after:after{
content:"";
display:block;
height:0;
line-height:0;
clear:both;
visibility:hidden;
} /*
--------------------------------------------- 采用CSS overflow:auto的方式撑高'
缺点多个嵌套后,点击最外层的轻浮动框会遭成最外层至最内层内容全选(FF);或者在mouseover造成宽度改变时会出现最外层模块有滚动条(IE)。
建议内个模块使用,请勿嵌套。
---------------------------------------------
*/
.clearfix_overflowauto{
overflow:auto;
zoom:1;
} /*
--------------------------------------------- 采用CSS overflow:hidden的方式产生怪异适应
缺点内容增多时候极易不会自动换行而内容被隐藏掉。
建议宽度固定时使用,请勿嵌套。
---------------------------------------------
*/
.clearfix_overflowhidden{
overflow:hidden;
zoom:1;
} /*
--------------------------------------------- 采用display:table将对象变成table形式应
缺点盒模型属性已经改变,可想而知奇异事件自然多得你数都数不到。
建议如果你不想改Bug改死你的话,最好不要使用;不过可以作为alpha版本当中临时性的忽悠下测试。
---------------------------------------------
*/
.clearfix_table{
display:table;
zoom:1;
}
/*采用div标签,以及css的clear属性*/
.clearfix_divclear .clear{clear:both;}
/*采用br标签,以及css的clear属性*/
.clearfix_brclear br.clear{clear:both;}
</style>
</head>
<body>
<ul class="clearfix_after">
clearfix_after
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul> <ul class="clearfix_overflowauto">
clearfix_overflowauto
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
<ul class="clearfix_overflowhidden">
clearfix_overflowhidden
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
<ul class="clearfix_table">
clearfix_table
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
<ul class="clearfix_divclear">
clearfix_divclear
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<div class="clear"></div>
</ul>
<ul class="clearfix_brclear">
clearfix_brclear
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<br class="clear"/>
</ul>
<ul class="clearfix_brclear2">
clearfix_brclear2
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
<br clear="all"/><!--采用br标签,以及其自身HTML的clear属性-->
</ul>
<ul>
normal
<li></li>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</body>
clearfix 清除浮动的问题的更多相关文章
- clearfix清除浮动
首先在很多很多年以前我们常用的清除浮动是这样的. 1 .clear{clear:both;line-height:0;} 现在可能还可以在很多老的站点上可以看到这样的代码,相当暴力有效的解决浮动的问题 ...
- css用clearfix清除浮动
本文从http://www.studyofnet.com/news/196.html复制. 本文导读:写css 时总为浮动而烦恼,如果用了浮动,浮动的父层不会跟着浮动框的高度增加而增加,在Fire ...
- [笔记]使用clearfix清除浮动
转载自奶牛博客 .clearfix { *zoom: 1; } .clearfix:before, .clearfix:after { display: table; line-height: 0; ...
- clearfix清除浮动进化史
我想大家在写CSS的时候应该都对清除浮动的用法深有体会,今天我们就还讨论下clearfix的进化史吧. clearfix清除浮动 首先在很多很多年以前我们常用的清除浮动是这样的. .clear{cle ...
- clear-fix清除浮动的两种写法
1. [代码]clearfix 清除浮动 .clearfix:after { content: "."; display: block; height: 0; font-size: ...
- css中clearfix清除浮动的用法及其原理示例介绍
clearfix的定义: .clearfix:after {}{ content: "."; /**//*内容为“.”就是一个英文的句号而已.也可以不写.*/ display: b ...
- CSS - clearfix清除浮动
首先,我们来解释一下为什么要使用 clearfix(清除浮动). 通常我们在写html+css的时候,如果一个父级元素内部的子元素是浮动的(float),那么常会发生父元素不能被子元素正常撑开的情况, ...
- .clearfix 清除浮动,@import
我们知道,在网页的DIV+CSS布局中,很多时候要用到浮动. 既然有浮动,那就有清除浮动. 清除浮动有很多种方式,而在实际项目中,比较常用的是这一种. .clearfix:after { conten ...
- ie7 用 clearfix 清除浮动时遇到的问题
<!doctype html> <html> <head> <style> .fr{float:right;display:inline} li{bor ...
随机推荐
- 相对布局RelativeLayout
一. public class RelativeLayout extends ViewGroup java.lang.Object ↳ android.view.View ↳ an ...
- 关于如何使用Navicat(11.1.13) for MySQL如何创建存储过程
1.ƒ()函数(右键)→新建函数(左键)→过程(选择) 2.会遇到的问题 问题一:因为sql语句默认以;为结束符,所以应该修改结束符,但是这在Navicat(11.1.13) for MySQL中是不 ...
- 深入Java集合学习系列:HashMap的实现原理--转
原文出自:http://www.cnblogs.com/xwdreamer/archive/2012/06/03/2532832.html 1. HashMap概述: HashMap是基于哈希表的Ma ...
- ssh超时断开的解决方法
当用SSH Secure Shell连接Linux时,如果几分钟没有任何操作,连接就会断开,必须重新登陆才行,每次都重复相同的操作,很是烦人,本文总结了两种解决的方法. 方法1:更改ssh服务器的配置 ...
- Quartz 2D Programming Guide
Quartz 2D Programming Guide 官方文档: Quartz 2D Programming Guide 译文: Quartz 2D编程指南(1) - 概览 Quartz 2D编程 ...
- 博弈的SG函数理解及模板
首先定义mex(minimal excludant)运算,这是施加于一个集合的运算,表示最小的不属于这个集合的非负整数.例如mex{0,1,2,4}=3.mex{2,3,5}=0.mex{}=0. 对 ...
- 关于 RTMP RTMPT RTMPS RTMPE RTMPTE RTMFP AMF 简介
http://www.360doc.com/content/13/0709/16/21412_298738723.shtml 1. AMFAMF(是Action Message Format的缩写)是 ...
- photoshop:css3插件
CSS3PS是Photoshop 插件,用来将 PhotoShop 的图层如内阴影.内发光.阴影.外发光.图片圆角等效果转成用 CSS3 样式. 官方下载地址>> http://css3p ...
- http://www.ibm.com/developerworks/cn/java/j-lo-junit-src/
http://www.ibm.com/developerworks/cn/java/j-lo-junit-src/
- POJ2126——Prime Path(BFS)
Prime Path DescriptionThe ministers of the cabinet were quite upset by the message from the Chief of ...