首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

兼容各浏览器匣子模型

2012-09-07 
兼容各浏览器盒子模型各浏览器盒模型的组成结构是一致的,区别只是在怪异模式下宽度和高度的计算方式,而“

兼容各浏览器盒子模型
   各浏览器盒模型的组成结构是一致的,区别只是在"怪异模式"下宽度和高度的计算方式,而“标准模式”下则没有区别。组成结构以宽度为例:总宽度=marginLeft+borderLeft+paddingLeft+contentWidth+paddingRight+borderRight+marginRight。页面在“怪异模式”下,css中为元素的width和height设置的值在标准浏览器和ie系列(ie9除外)里的代表的含义是不同的。
   因而解决兼容型为题最简洁和值得推荐的方式是:下述的第一条。
一、将页面设为“标准模式”。
添加对应的dtd标识,如:


注意:offsetWidth=borderLeft+paddingLeft+contentWidth+paddingRight+borderRight。
此时alert的值是160:100。即,各浏览器均认为css中的width就是100px即内容的宽度,和padding+border最终相加结果是:160px。
如果把doctype去掉,即进入“怪异模式”,此时,ie6/7/8的值均为100:40,证明它们认为css中width指的和offsetWidth是同一个值,除了内容的宽度外还都包含补白和边框,而内容的宽度则被压缩为40。而ie9,ff,chrome,opera这样的标准浏览器则依然是160:100。
二、使用hack或者在外面套上一层wrapper。
前提是页面处于“怪异模式”,“标准模式”不存在兼容性问题。
1、hack
   依然使用上例:假设内容的宽度必须固定为100px。
div {margin:0 auto;}


查询类似问题可以访问网址http://www.quirksmode.org/css/contents.html
  

热点排行