(三)盒子模型

129 阅读6分钟

1. 盒子模型

1.1 看透网页布局的本质

网页布局过程:

  1. 准备网页元素,网页元素基本都是盒子 box
  2. 利用 CSS 设置好盒子样式,然后摆放到相应位置。
  3. 往盒子里放东西。

本质:利用 CSS 摆盒子。

1.2 盒子模型(Box Model)组成

CSS 盒子模型本质上是一个盒子,封装周围的 HTML 元素,包括:边框、内边距、实际内容和外边距。

1.3 边框(border)

border 可以设置元素边框。边框有三个组成:border-widthborder-styleborder-color

语法:

/*属性可连写*/
border: border-width || border-style || border-color;
属性作用
border-width定义边框粗细,单位 px
border-style边框样式,solid实线边框、dashed虚线边框、dotted点线边框
border-color边框颜色

边框属性简写:

/*习惯顺序*/
    border: 5px solid pink;

边框属性分写:

 /*注意层叠性*/
    border-top: 1px solid red;

1.4 表格的细线边框

border-collapse 属性控制浏览器绘制表格边框的方式。它控制相邻单元格的边框。

语法

    border-collapse: collapse;
  • collapse 是合并的意思
  • border-collapse:collapse; 表示将相邻边框合并在一起

1.4 边框会影响盒子实际大小

边框会额外增加盒子的实际大小,因此有两种方案解决。

  1. 测量盒子大小的时候,不测边框。
  2. 若测量的时候包含了边框,则需要 width/height - 边框宽度。

1.6 内边距 padding

padding 属性设置内边距,即边框与内容之间的距离。

  • padding-left: 左内边距
  • padding-right: 右内边距
  • padding-top: 上内边距
  • padding-bottotm: 下内边距

1 padding 属性简写

padding 的值的个数:

  • 1 个值:上下左右
  • 2 个值:上下,左右
  • 3 个值:上,左右,下
  • 4 个值:上,右,下,左,顺时针

2 padding 会影响盒子实际大小

当给盒子指定了 padding 值以后,发生了两件事情:

  1. 内容和边框有了距离,增加内边距
  2. padding 值影响了盒子实际大小

也就是说,当盒子已经有了宽度和高度,再指定内边距,会撑大盒子。

如果盒子本身没有指定宽度和高度属性,则此时padding不会撑开盒子大小。

要保证盒子和效果图一样大,则让 width/height减去多出来的内边距大小即可。

3 padding撑开盒子的好处-新浪导航栏案例

1.7 外边距

margin 属性用于设置外边距,即控制盒子与盒子之间的距离。

  • margin-left: 左外边距
  • margin-right: 右外边距
  • margin-top: 上外边距
  • margin-bottotm: 下外边距

margin 简写方式与 padding 一致。

1.8 外边距典型应用

外边距可以让块级盒子 水平居中,但是必须满足两个条件:

  1. 盒子必须指定宽度(width)
  2. 盒子左右的外边距都设置为 auto
.header {
  width: 900px;  /*指定宽度*/
  margin: 0 auto;
}

使行内元素或行内块元素水平居中

text-align: center;

1.10 外边距合并

1. 相邻元素垂直外边距的合并

当上下相邻块元素相遇时,若上面的元素有下外边距,下面的元素有上外边距,则他们之间的垂直间距不是 margin-bottotm 与 margin-top 之和。取两个值中的较大者这种现象被称为相邻元素垂直外边距的合并

2. 嵌套块元素垂直外边距的塌陷

对于两个嵌套关系的块元素,父元素有上外边距同时子元素也有上外边距,此时父元素会塌陷较大的外边距值。

解决方案

  1. 为父元素定义上边框
  2. 为父元素定义上内边距
  3. 为父元素添加 overflow:hidden 还有其他方法:如浮动、固定、绝对定位的盒子不会有塌陷问题。

1.11 清除内外边距

网页元素很多都带有默认内外边距,而且不同浏览器默认的也不一致,因此在布局前,要先清除网页元素的内外边距。

语法:

  * {
      margin: 0;
      padding: 0;
  }

注意:行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距。但是转换为块级和行内块元素就可以设置。

综合案例-产品模块

<style>
    * {
        margin: 0;
        padding: 0;
    }
    body {
        background-color: #f5f5f5;
    }
    .box {
        width: 298px;
        height: 415px;
        background-color: #fff;
        margin: 100px auto;  /* 让块级盒子水平居中对齐 */
    }
    .box img {
        width: 100%;  /* 图片宽度和父亲一样宽 */
    }
    .review {
        height: 70px;
        font-size: 14px;
        /* 因为这个段落没有Width属性,所以指定padding值不会撑大盒子 */
        padding: 0 28px;
        /* 这个段落有height属性,所以指定margin-top值不会撑大盒子 */
        margin-top: 30px;
    }
    .appraise {
        color: #b0b0b0;
        font-size: 12px;
        margin-top: 20px;
        padding: 0 28px;
    }
    .info {
        font-size: 14px;
        margin-top: 15px;
        padding: 0 28px;
    }
    .info h4 {
        display: inline-block;
        font-weight: 400;
    }
    a {
        color: #333;
        text-decoration: none;
    }
    .info span {
        color: #ff6700;
    }
    .info em {
        font-style: normal;
        color: #ebe4e0;
        margin: 0 6px 0 15px;  /* 盒子与盒子之间用margin */
    }
</style>
<body>
    <div class="box">
        <img src="images/img.png" alt="">
        <p class="review">快递牛,整体不错蓝牙可以说秒连。红米给力</p>
        <div class="appraise">来自于117384232的评价</div>
        <div class="info">
            <h4><a href="#">Redmi AirDots真无线蓝...</a></h4>
            <em>|</em>
            <span>99.9元</span>
        </div>
    </div>
</body>

综合案例-快报模块

2. PS 基本操作

  • 文件->打开:打开测量的图片
  • Ctrl+r :打开标尺,或者视图->标尺
  • 鼠标拖动标尺可将标尺移动到PS图片上
  • 右击标尺,将单位改为像素
  • Ctrl+-:放大/缩小视图
  • 按住空格键,鼠标可以拖动PS视图
  • 用选区拖动,可以测量大小
  • Ctrl+D 可以取消选区,或者在旁边空白处点击一下也可以取消选区

3. 圆角边框

CSS3 新增 圆角边框 属性,盒子可以变成圆角。

border-radius 属性用于设置元素的外边框圆角。

语法:

border-radius: 10px;

原理:

radius圆的半径:(椭)圆与边框的交集形成的圆角效果。

参数

  • 参数值可以为数值百分比的形式
  • 若是正方形,想要设置一个圆,则将数值修改为高度或者宽度的一半即可,或者直接写为 50%
  • 若是矩形,设置为 height 的一半就可以做圆角矩形。
  • 简写属性,跟四个值,分别代表左上角、右上角、右下角、左下角
  • 分开来写:border-top-left-radiusborder-top-right-radiusborder-bottom-right-radiusborder-bottom-left-radius

4. 盒子阴影

CSS3 新增盒子阴影,使用 box-shadow 属性。

语法

bxo-shadow: h-shadow v-shadow blur spread color inset;
描述
h-shadow必需,水平阴影的位置,允许负值
v-shadow必需,垂直阴影的位置,允许负值
blur可选,模糊距离(虚实)
spread可选,阴影的尺寸
color可选,阴影的颜色
inset可选,将外部阴影outset改为内部阴影(默认是外部阴影)

注意:

  1. 默认是外阴影,但是不可以写这个单词(outset)
  2. 盒子阴影不占空间,不会影响其他盒子排列

5. 文字阴影

CSS3 中,使用 text-shadow 属性设置文本阴影。

描述
h-shadow必需,水平阴影位置。允许负值。
v-shadow必须,垂直阴影。允许负值。
blur可选,模糊距离。
color可选,阴影颜色。