W3标准不变 清除浮动实现代码
发布时间:2012-05-27 04:21:16 作者:佚名 我要评论
对于日新月异的WEB开发技术和浏览器更新频率来说,清除浮动已然是一个被人嚼碎了的话题。说是这些年过去了,有关float的地方,还依然少不了清除浮动的标签和css代码
(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun)
W3C整天研究html5,就不能抽出点时间来把这种烦人的小细节修正一下吗?抱怨归抱怨,饭还得吃,钱还得挣,清除浮动就不能停止。
为了清除浮动增加无语义代码已经是最稳定和简单的方式,但总叫开发者心里感到不舒服,毕竟这么多年来早已习惯了结构和样式的分离,非要在结构中插入这样一行无语义代码就会让人觉得有种难以掌握的感受。
通过css代码清除浮动也不省油,光是当前这种多个浏览器瓜分浏览器份额的状况所带来的各种css hack就够让人头疼的了,而且这还没说到那些个浏览器的不同版本之间又有多少的差别。通过css清除浮动还是一个长期的过程,因为你还要期盼下一牌浏览器没有针对浮动修改对html代码的解释。
要说在当前这种恶劣的状况下,选取哪种方式去清除浮动最为可取,这事一个人说了不算,要看大家的意见。
很多时候,开发人员在前端开发时遇到问题,就会去找那些运用了类似技术的大型网站,去分析它们的解决方案,然后用到自己的网站上,连为什么都省得去想了。我也常常这么做。具体到清除浮动这个问题上,我现在所用的无语义标签法就是在看到某大型网站用过之后,我才选用的。
不过今天重提这个问题,是因为我又在一个大型网站上看到了不同的方案。它们是这样做的:
<style>
.clearfix:after{
visibility: hidden;
display: block;
font-size: 0;
content: ".";
clear: both;
height: 0;
}
* html .clearfix{zoom: 1;}
*:first-child + html .clearfix{zoom: 1;}
</style>
<div class="clearfix" style="border: 2px solid red;">
<div style="float: left; width: 80px; height: 80px; border: 1px solid blue;">
我的网站
</div>
</div>
虽说这是来自大型网站,可信任度很高,可以不去思考而直接用,但学习的态度还是要有,就此分析一下其中的原理。
1)首先是利用:after伪类来兼容支持这一标准的浏览器们,FF、Chrome自然属于强烈支持标准的浏览器行列,不过IE自从繁殖到第八代开始,也表示支持这一伪类。:after伪类用来和content属性一起使用设置在对象后的内容。
如果现在不是2012看,而是10年后,可能就不用再往下讲了。但因为现在IE6和IE7还很有势力,所以,我们还得好好照顾它们。:after伪类IE不支持,它用来和content属性一起使用设置在对象后的内容,例如:
.clearfix:after {content:".";}
这个CSS将会让clearfix类标签内的文本后边加上英文句号。
3)"* html"这个选择符只有IE6才能识别,因此在其中设置缩放属性"zoom: 1;",便可实现兼容IE6;"*:first-child + html"这个选择符只有IE7才能识别,因此设置缩放属性"zoom: 1;" 便可实现兼容IE7。
原理分析完毕。方法是可行的,完美解决是不可能的。所以,W3标准中的浮动一天不变,清除浮动就会一天不止。
为了清除浮动增加无语义代码已经是最稳定和简单的方式,但总叫开发者心里感到不舒服,毕竟这么多年来早已习惯了结构和样式的分离,非要在结构中插入这样一行无语义代码就会让人觉得有种难以掌握的感受。
通过css代码清除浮动也不省油,光是当前这种多个浏览器瓜分浏览器份额的状况所带来的各种css hack就够让人头疼的了,而且这还没说到那些个浏览器的不同版本之间又有多少的差别。通过css清除浮动还是一个长期的过程,因为你还要期盼下一牌浏览器没有针对浮动修改对html代码的解释。
要说在当前这种恶劣的状况下,选取哪种方式去清除浮动最为可取,这事一个人说了不算,要看大家的意见。
很多时候,开发人员在前端开发时遇到问题,就会去找那些运用了类似技术的大型网站,去分析它们的解决方案,然后用到自己的网站上,连为什么都省得去想了。我也常常这么做。具体到清除浮动这个问题上,我现在所用的无语义标签法就是在看到某大型网站用过之后,我才选用的。
不过今天重提这个问题,是因为我又在一个大型网站上看到了不同的方案。它们是这样做的:
复制代码
代码如下:<style>
.clearfix:after{
visibility: hidden;
display: block;
font-size: 0;
content: ".";
clear: both;
height: 0;
}
* html .clearfix{zoom: 1;}
*:first-child + html .clearfix{zoom: 1;}
</style>
<div class="clearfix" style="border: 2px solid red;">
<div style="float: left; width: 80px; height: 80px; border: 1px solid blue;">
我的网站
</div>
</div>
虽说这是来自大型网站,可信任度很高,可以不去思考而直接用,但学习的态度还是要有,就此分析一下其中的原理。
1)首先是利用:after伪类来兼容支持这一标准的浏览器们,FF、Chrome自然属于强烈支持标准的浏览器行列,不过IE自从繁殖到第八代开始,也表示支持这一伪类。:after伪类用来和content属性一起使用设置在对象后的内容。
如果现在不是2012看,而是10年后,可能就不用再往下讲了。但因为现在IE6和IE7还很有势力,所以,我们还得好好照顾它们。:after伪类IE不支持,它用来和content属性一起使用设置在对象后的内容,例如:
复制代码
代码如下:.clearfix:after {content:".";}
这个CSS将会让clearfix类标签内的文本后边加上英文句号。
3)"* html"这个选择符只有IE6才能识别,因此在其中设置缩放属性"zoom: 1;",便可实现兼容IE6;"*:first-child + html"这个选择符只有IE7才能识别,因此设置缩放属性"zoom: 1;" 便可实现兼容IE7。
原理分析完毕。方法是可行的,完美解决是不可能的。所以,W3标准中的浮动一天不变,清除浮动就会一天不止。
相关文章
- 这篇文章主要分享的是web技术的 AudioContext 实现音频可视化,要实现音频可视化得先实现一些炫酷的效果需要借助 Web Audio API提供的一些方法 AudioContext,下面详细内容2022-02-23
- 这篇文章主要给大家介绍了web技术中的WebRTC记录音视频流,文章内容围绕主题展相关资料,需要的小伙伴可以参考一下,希望对你有所帮助2022-02-23
- 这是我通过网上查阅资料总结的一些编码规范,用于巩固对html,css页面重构时的基础,需要的朋友可以参考下2020-12-19
前端编码规范(4)—— CSS 和 Sass (SCSS) 开发规范
这篇文章主要介绍了前端编码规范(4)—— CSS 和 Sass (SCSS) 开发规范,需要的朋友可以参考下2017-01-21Web前端开发规范2017(HTML/JavaScript/CSS)
这是一份旨在增强团队的开发协作,提高代码质量和打造开发基石的编码风格规范,其中包含了 HTML, JavaScript 和 CSS/SCSS 这几个部分。我们知道,当一个团队开始指定并实行2017-01-21- 这篇文章主要为大家介绍了前端开发团队遵循和约定的代码书写规范,意在提高代码的规范性和可维护性,需要的朋友可以参考下2017-01-21
- 这篇文章主要为大家详细介绍了响应式Web之流式网格系统的相关资料,感兴趣的小伙伴们可以参考一下2016-07-04
- 下面小编就为大家分享一篇在网页标题栏上和收藏夹显示网站logo的实现方法。希望对大家有所帮助。一起跟随小编过来看看吧,祝大家游戏愉快哦2016-03-16
- 基于很多用户都在下载Visual Foxpro 6.0,但是有安装vtp6.0经验的朋友确很少,在安装过程中总会出现这样那样的问题,基于这些问题,下面小编抽个时间把Visual Foxpro 6.02015-09-09
- 网站日志200 0 64状态码的分析介绍2012-10-29
最新评论