本帖最后由 西安前端组 于 2018-2-1 12:46 编辑
盒子模型
什么是盒子模型?所谓盒子模型就是把HTML页面中的元素看作是一个矩形的盒子,也就是一个盛装内容的容器。每个矩形都由元素的内容、内边距(padding)、边框(border)和外边距(margin)组成。理解了这个重要的概念才能更好的排版,进行页面布局。 一、 css盒子模型概念 css盒子模型又称框模型 (Box Model) ,包含了元素内容(content)、内边距(padding)、边框(border)、外边距(margin)几个要素。
图中最内部的框是元素的实际内容,紧挨着元素框外部的是内边距padding,其次是边框(border),然后最外层是外边距(margin),整个组成了盒子模型。实际使用中要计算元素的宽高,元素框的总宽度 = 元素(element)的width+ padding的左边距和右边距的值 + margin的左边距和右边距的值 + border的左右宽度;元素框的总高度 = 元素(element)的height + padding的上下边距的值 + margin的上下边距的值 + border的上下宽度。 二、css 外边距合并(margin塌陷) 外边距合并是一个相当简单的概念。但是,在实践中对网页进行布局时,它会造成许多混淆。简单地说,外边距合并指的是,当两个垂直外边距相遇时,它们将形成一个外边距。合并后的外边距的高度等于两个发生合并的外边距的高度中的较大者。外边距合并有两种情况,如下图所示: 1、当一个元素出现在另一个元素上面时,第一个元素的下外边距与第二个元素的上外边距会发生合并。请看下图:
2、当一个元素包含在另一个元素中时(假设没有内边距或边框把外边距分隔开),它们的上和/或下外边距也会发生合并。请看下图:
外边距合并初看上去可能有点奇怪,但是实际上,它是有意义的。以由几个段落组成的典型文本页面为例。第一个段落上面的空间等于段落的上外边距。如果没有外边距合并,后续所有段落之间的外边距都将是相邻上外边距和下外边距的和。这意味着段落之间的空间是页面顶部的两倍。如果发生外边距合并,段落之间的上外边距和下外边距就合并在一起,这样各处的距离就一致了。 需要注意的是:只有普通文档流中块框的垂直外边距才会发生外边距合并。行内框、浮动框或绝对定位之间的外边距不会合并。 在页面中,经常会移除元素的内外边距: * { margin : 0; padding : 0; }
三、box-sizing属性介绍 该属性取不同的值会决定box高宽不同的计算方式。先来说说兼容性,目前测试IE9以上版本以及其他现代浏览器都兼容这个属性。这个属性有三个可取值,分别是:content-box,padding-box,border-box,默认值为content-box。 1、content-box(默认值) 这也就是最常规的计算方式,某个box的高等于它的height+padding+border+margin,宽也是同理。 2、border-box 当取值为border-box时,这个box的高就等于它的height+margin了,也就是说该box的height是由content部分的height和padding以及border共同组成的了,换言之,padding和border不再向外延伸,而是往里边挤。 四、用盒子模型画小三角 <!DOCTYPEhtml> <html> <head> <metahttp-equiv="Content-Type"content="text/html;charset=UTF-8"> <title>Document</title> <style type="text/css"> div { width: 0px; height: 0px; margin: 100px auto; border-width: 10px; /* 数值控制三角大小 */ border-color: #00f transparenttransparent transparent ; /* 上 右 下 左 模式 */ /* transparent透明 背景颜色默认也是透明的 */ border-style: solid dashed dasheddashed; /* dashed 是为了照顾ie6 灰色底的问题*/ overflow: hidden; /* ie6 高度问题 */ } </style> </head> <body> <div></div> </body> </html> 页面显示结果为:
总结,网页布局其实就是在页面中摆盒子,把特定的元素放到页面的某个位置。明白了盒子模型的概念和组成之后就可以愉快地用盒子写页面了。
|