前端基础之CSS(下)

第十三章 盒子模型

• 盒子模型

– 盒子模型就是一个有高度和宽度的矩形区域

– 所有html标签都是盒子模型

– div标签自定义盒子模型

• 所有的标签都是盒子模型

– class和id的主要差别是:class用于元素组(类似的元素,或者可以理解为某一类元素),而id用于标识单独的唯一的元素。

• 盒子模型的组成

– 盒子模型组成部分:

• 自身内容:width、height 宽高

• 内边距: padding

• 盒子边框: border 边框线

• 与其他盒子距离: margin外边距

• 内容+内边距+边框+外边距=面积

• border 边框

– 常见写法 border:1px solid #f00;

• 单独属性:

• border-width:

• border-style:

– dotted 点状虚线

– dashed(虚线)

– solid(实线)

– double(双实线)

• border-color (颜色)

• padding 内边距

– 值:像素/厘米等长度单位、百分比

• padding:10px; 上下左右

• padding:10px 10px; 上下 左右

• padding:10px 10px 10px; 上 左右 下

• padding:10px 10px 10px 10px; 上 右 下 左(设置4个点-->顺时针方向)

• 单独属性:

– padding-top:

– padding-right:

– padding-bottom:

– padding-left:

• 当设置内边距的时候会把盒子撑大,为了保持盒子原来的大小,应该高度和宽度进行减小,根据width和height减小

• margin 外边距

– 值:与padding相同

– 单独属性:与padding相同

• 外边距合并:两个盒子同时设置了外边距,会进行一个外边距合并

补充盒子模型内容

• 标准盒子模型

• 盒子模型是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 盒子模型”。

你用的盒子模型是标准w3c盒子模型

• 代码2 与代码1 唯一的不同的就是顶部加了 doctype声明。在所有浏览器中都显示“标准 w3c盒子模型”

所以为了让网页能兼容各个浏览器,让我们用标准 w3c 盒子模型

IT技术大神∣小白到大神的进阶之路

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180322B0KTI600?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励