第十三章 盒子模型
• 盒子模型
– 盒子模型就是一个有高度和宽度的矩形区域
– 所有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技术大神∣小白到大神的进阶之路
领取专属 10元无门槛券
私享最新 技术干货