CSS 对於 Float 的 clear:both 每年都会有新的写法. XD
2008、2010 年的 clear:both 写法
不过, 在今年看到此篇: Best Cross-browser CSS Clearfix solution, 跟上述那篇比对起来, 参数多增加了几个, 到底有何差异, 就不细究了~ 直接用就对了. XD
CSS 的 float 使用起来蛮方便的, 但是使用完后, 那块空间就等於是消失, 所以需在下面加 clear:left / clear:right / clear:both (我通常都直接 clear:both 就是了~), 但是有时后会遇到写 clear:both, 但是没有任何作用的状况.
这篇文章也是早就想写, 正好看到 「修正因? float 导致区块无法撑开的问题」 这篇, 该说明的都说很齐全, 所以直接来写写结论就好了~~
我现在 CSS 都会规画一个 "/* common */" 的区块, 那边就会定义一些共用的 class, 和 clear 相关的就是下述:
代码如下.clear {zoom:1; clear:both;}
.clear:after {content:""; display:block; clear:both; visibility:hidden; height:0;}
主要就是这两段, 遇到 float 完后, 要清除的地方, 写个
就可以了~不过, 上述的第一段 ".clear {}" 这段, 有些人是不用加的, 或者只有写 ".clear{zoom:1;}" 而已, 但是我使用起来就是有些问题, 所以还是把 "clear:both;" 都加上去.(跟下述的写法有些不同的地方, 我现在也解释不出来, 总之先都记著, 遇到或许就知道了.. XD)
想知道?楹我?茨屈N多东西, 请参照下述两篇:
■如何修正 DIV float 之后导致的外部容易不能撑开的问题
■How To Clear Floats Without Structural Markup(Clearing a float container without source markup)
直接摘取他们的结论, 就是加 clearfix 的 class 即可, 跟我上面目前用的有点不同, 但是差异我现在还不清楚, 要再测试看看, 他们的写法应该周全很多:
.clearfix:after {
content: ".";
display: block;
height: 0;
clear: both;
visibility: hidden;
}
.clearfix {display: inline-block;}
/* Hides from IE-mac */
* html .clearfix {height: 1%;}
.clearfix {display: block;}
/* End hide from IE-mac */
CSS .clearfix 写法 (摘录自上述: Best Cross-browser CSS Clearfix solution)
代码如下 .clearfix:after {
content: ".";
display: block;
clear: both;
visibility: hidden;
line-height: 0;
height: 0;
}
.clearfix {
display: inline-block;
}
html[xmlns] .clearfix {
display: block;
}
* html .clearfix {
height: 1%;
overflow: visible;
}
2011 年到了, 今年的解法可见此文: A new micro clearfix hack # 下述取自此文
代码如下
/* For modern browsers */
.cf:before,
.cf:after {
content:"";
display:block;
overflow:hidden;
}
.cf:after {
clear:both;
}
/* For IE 6/7 (trigger hasLayout) */
.cf {
zoom:1;
}
[css中字体加粗]CSS中 Float 的 clear:both 无效的解法
http://m.bbyears.com/kuzhan/42947.html
推荐访问:css中position css中文字体样式 css中display css中margin和padding的区别 css中hover css中display有哪些属性 css中的position css中的空格 css中上下文选择符