标准盒子模型和IE盒子模型
source link: http://www.poetries.top/2016/09/05/%E6%A0%87%E5%87%86%E7%9B%92%E5%AD%90%E6%A8%A1%E5%9E%8B%E5%92%8CIE%E7%9B%92%E5%AD%90%E6%A8%A1%E5%9E%8B/
Go to the source link to view the article. You can view the picture content, updated content and better typesetting reading experience. If the link is broken, please click the button below to view the snapshot at that time.
标准盒子模型和IE盒子模型
Created at 2016-09-05 Updated at 2017-01-06 Category Front-End Tag CSS
标准盒子模型
- 盒子模型是css中一个重要的概念,理解了盒子模型才能更好的排版。其实盒子模型有两种,分别是 ie 盒子模型和标准 w3c 盒子模型。他们对盒子模型的解释各不相同,先来看看我们熟知的标准盒子模型
- 从上图可以看到标准
w3c
盒子模型的范围包括margin
、border
、padding
、content
,并且content
部分不包含其他部分
IE盒子模型
- 从上图可以看到
ie
盒子模型的范围也包括margin
、border
、padding
、content
- 和标准
w3c
盒子模型不同的是:ie
盒子模型的content
部分包含了border
和padding
IE
盒子模型width
=padding
+border
+内容
标准盒子模型 = 内容的宽度(不包含
border
+padding
)一个盒子的
margin
为 20px,border
为 1px,padding
为 10px,content
的宽为 200px、高为 50px,假如用标准w3c
盒子模型解释,那么这个盒子需要占据的位置为:宽20*2+1*2+10*2+200=262px
、高20*2+1*2*10*2+50=112px
,盒子的实际大小为:宽1*2+10*2+200=222px
、高1*2+10*2+50=72px
;假如用ie 盒子模型,那么这个盒子需要占据的位置为:宽20*2+200=240px
、高20*2+50=70px
,盒子的实际大小为:宽200px
、高50px
那应该选择哪中盒子模型呢?当然是“标准
w3c
盒子模型”了。怎么样才算是选择了“标准w3c
盒子模型”呢?很简单,就是在网页的顶部加上doctype
声明。- 假如不加
doctype
声明,那么各个浏览器会根据自己的行为去理解网页,即ie
浏览器会采用ie
盒子模型去解释你的盒子,而ff
会采用标准 w3c 盒子模型解释你的盒子,所以网页在不同的浏览器中就显示的不一样了。 - 反之,假如加上了 doctype 声明,那么所有浏览器都会采用标准
w3c
盒子模型去解释你的盒子,网页就能在各个浏览器中显示一致了。
- 再用 jquery 做的例子来证实一下
- 上面的代码没有加上
doctype
声明,在ie
浏览器中显示ie
盒子模型,在 ff 浏览器中显示“标准w3c
盒子模型”。
- 代码2 与代码1 唯一的不同的就是顶部加了
doctype
声明。在所有浏览器中都显示“标准w3c
盒子模型” - 所以为了让网页能兼容各个浏览器,让我们用标准
w3c
盒子模型
Recommend
About Joyk
Aggregate valuable and interesting links.
Joyk means Joy of geeK