【前端-初阶】CSS盒子模型

文章详细介绍了网页布局中的核心概念——盒子模型,包括边框、内边距、外边距的设置和影响,以及如何通过CSS实现元素的边框合并、清除内外边距,同时还涉及到了表格的细线边框和CSS3的新特性如圆角边框和盒子阴影。
摘要由CSDN通过智能技术生成

1.盒子模型

页面布局要学习三大核心,盒子模型,浮动定位。学习好盒子模型能非常好的帮助我们布局页面

1.1 看透网页布局本质

网页布局过程:

1、先准备好相关的网页元素,网页元素基本上都是盒子box。

2、利用CSS设置好盒子样式,然后摆放到相应位置

3、往盒子里面装内容

网页布局的核心本质:就是利用CSS摆盒子。

1.2 盒子模型(Box Model)组成

所谓盒子模型:就是把HTML页面中的布局元素看作一个矩形的盒子,也就是一个盛装内容的容器。

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

外边距margin

边框border

内边距padding

内容content

1.3 边框(border)

border可以设置元素边框。边框有三部分组成:边框粗细、边框样式、边框颜色

语法:

border:border-width || border-style || border-color

属性作用
border-width定义边框粗细,单位是px
border-style边框的样式
border-color边框颜色
 <style>
     div {
         width: 300px;
         height: 200px;
         /* boder-width 边框粗细 一般情况下都用px */
         border-width: 5px;
         /* border-style 边框的样式 solid-实线边框 dashed-虚线边框 dotted-点线边框 */
         border-style: dotted;
         border-color: pink;
     }
 </style>
 ​
 <body>
     <div></div>
 </body>

边框简写:

border:1px solid red; 没有顺序

边框分开写法:

border-top:1px solid red; /* 只设定上边框,其余同理 */

  • top、bottom、left、right

课堂要求:请给一个200*200的盒子,设置上边框为红色,其余边框为蓝色(提示:一定注意边框的层叠性)

 <style>
     div {
         width: 200px;
         height: 200px;
         /* border-top: 5px solid red;
         border-bottom: 5px dashed blue;
         border-left: 1px solid blue;
         border-right: 3px dotted blue; */
         /* border包含四条边 */
         border: 1px solid blue;
         /* 层叠性 只是层叠了上边框 就近原则 顺序不能变 */
         border-top: 1px solid red;
     }
 </style>

1.4 表格的细线边框

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

语法:

border-collapse:collapse;

  • collapse单词是合并的意思;

  • border-collapse:collapse,表示相邻边框合并在一起

     <style>
         table {
             width: 500px;
             height: 249px;
         }
 ​
         th {
             height: 35px;
         }
 ​
         table,
         th,
         td {
             border: 1px solid red;
             border-collapse: collapse;
             font-size: 14px;
             text-align: center;
         }
     </style>
 ​
 <body>
     <table align="center" cellspacing="0">
         <thead>
             <tr>
                 <th>排名</th>
                 <th>关键词</th>
                 <th>趋势</th>
                 <th>进入搜索</th>
                 <th>最近七日</th>
                 <th>相关链接</th>
             </tr>
         </thead>
         <tbody>
             <tr>
                 <td>1</td>
                 <td>鬼吹灯</td>
                 <td>↓</td>
                 <td>456</td>
                 <td>123</td>
                 <td> <a href="#">贴吧</a> <a href="#">图片</a> <a href="#">百科</a> </td>
             </tr>
 ​
             <tr>
                 <td>1</td>
                 <td>鬼吹灯</td>
                 <td>↑</td>
                 <td>456</td>
                 <td>123</td>
                 <td> <a href="#">贴吧</a> <a href="#">图片</a> <a href="#">百科</a> </td>
             </tr>
             <tr>
                 <td>3</td>
                 <td>西游记</td>
                 <td>↑</td>
                 <td>456</td>
                 <td>123</td>
                 <td> <a href="#">贴吧</a> <a href="#">图片</a> <a href="#">百科</a> </td>
             </tr>
             <tr>
                 <td>1</td>
                 <td>鬼吹灯</td>
                 <td>↓</td>
                 <td>456</td>
                 <td>123</td>
                 <td> <a href="#">贴吧</a> <a href="#">图片</a> <a href="#">百科</a> </td>
             </tr>
             <tr>
                 <td>1</td>
                 <td>鬼吹灯</td>
                 <td>↓</td>
                 <td>456</td>
                 <td>123</td>
                 <td> <a href="#">贴吧</a> <a href="#">图片</a> <a href="#">百科</a> </td>
             </tr>
             <tr>
                 <td>1</td>
                 <td>鬼吹灯</td>
                 <td>↑</td>
                 <td>456</td>
                 <td>123</td>
                 <td> <a href="#">贴吧</a> <a href="#">图片</a> <a href="#">百科</a> </td>
             </tr>
         </tbody>
     </table>
 </body>

1.5 边框会影响盒子的实际大小

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

  1. 测量盒子大小的时候,不量边框

  2. 如果测量的时候包含了边框,则需要width、height减去边框宽度

1.6 内边距(padding)

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

属性作用
padding-left左内边距
padding-right右内边距
padding-top上内边距
padding-bottom下内边距

padding属性(简写属性)可以有一到四个值。

值的个数表达意思
padding:5px; 1个值padding:上下左右内边距;
padding:5px 10px; 2个值padding: 上下内边距 左右内边距 ;
padding:5px 10px 20px; 3个值padding:上内边距 左右内边距 下内边距;
padding:5px 10px 20px 30px; 4个值padding: 内边距 内边距 内边距 内边距 ;(顺时针)

以上4种情况,我们实际开发都会遇到。

当我们给盒子指定padding值之后,发生了2件事情:

1、内容和边框有了距离,添加了内边距。

2、padding也会影响盒子的实际大小。

也就是说,如果盒子已经有了宽度和高度,此时再指定内边框,会撑大盒子。

解决方案:

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

案例:新浪导航案例-padding影响盒子好处

padding内边距可以撑开盒子,我们可以做非常巧妙的运用。

因为每个导航栏里面的字数不一样多,我们可以不用给每个盒子宽度了,直接给padding最合适。

     <style>
         .nav {
             height: 41px;
             border-top: 3px solid #ff8500;
             border-bottom: 1px solid #edeef0;
             background-color: #fcfcfc;
             line-height: 41px;
         }
 ​
         .nav a {
             font-size: 12px;
             color: #4c4c4c;
             text-decoration: none;
             display: inline-block;
             height: 41px;
             padding: 0 20px;
         }
 ​
         .nav a:hover {
             color: #ff8500;
             background-color: #d3d3d3;
         }
     </style>
 ​
 <body>
     <div class="nav">
         <a href="#">设为首页</a>
         <a href="#">手机新浪网</a>
         <a href="#">移动客户端</a>
     </div>
 </body>

如果盒子本身没有width、height属性,则此时padding不会撑开盒子大小。

1.7 外边距(margin)

margin属性用于设置外边距。margin就是控制盒子和盒子之间的距离

设置

属性作用
margin-left左外边距
margin-right右外边距
margin-top上外边距
margin-bottom下外边距

margin值的简写 (复合写法)代表意思 跟 padding 完全相同。

外边距的典型应用

块级盒子水平居中:

  • 盒子必须指定宽度(width)

  • 然后就给左右的外边距都设置为auto

实际工作中常用这种方式进行网页布局,示例代码如下:

 .header  { width: 960px; margin: 0 auto;}

常见的写法,以下下三种都可以。

  • margin-left: auto; margin-right: auto;

  • margin: auto;

  • margin: 0 auto;

注:以上方法是让块级元素居中,行内元素或者行内块元素水平居中给其父级元素添加text-algin:center即可。

文字居中和盒子居中区别

  1. 盒子内的文字水平居中是 text-align: center; 而且还可以让 行内元素和行内块居中对齐

  2. 块级盒子水平居中 左右margin 改为 auto

插入图片和背景图片区别

  1. 插入图片我们用的最多 比如产品展示类 移动位置只能靠盒模型 padding margin

  2. 背景图片我们一般用于小图标背景或者超大背景图片、背景图片,移动位置只能通过 background-position

清除元素的默认内外边距

  • 行内元素为了照顾兼容性,尽量只设置左右内外边距,不要设置上下内外边距。

 * {
    padding:0;         /* 清除内边距 */
    margin:0;          /* 清除外边距 */
 }

1.8 外边距合并

使用margin定义块元素的垂直外边距时,可能会出现外边距的合并。

1.8.1 相邻块元素垂直外边距的合并

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

解决方案:尽量给只给一个盒子添加margin值

1.8.2 嵌套块元素垂直外边距的合并(塌陷)

对于两个嵌套关系的块元素,如果父元素没有上内边距及边框,父元素的上外边距会与子元素的上外边距发生合并,合并后的外边距为两者中的较大者

解决方案:

  1. 可以为父元素定义上边框。

  2. 可以为父元素定义上内边距

  3. 可以为父元素添加overflow: hidden。

 <style>
     .father {
         width: 400px;
         height: 400px;
         background-color: skyblue;
         margin-top: 40px;
         /* border: 1px solid transparent; */
         /* padding: 1px; */
         overflow: hidden;
     }
 ​
     .son {
         width: 200px;
         height: 200px;
         background-color: pink;
         margin-top: 40px;
 ​
     }
 </style>
 ​
 <body>
     <div class="father">
         <div class="son"></div>
     </div>
 </body>

还有其他方法,比如浮动、固定、绝对定位的盒子不会有问题,后面咱们再总结。。。

1.9 清除内外边距

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

 <style>
     * {
         padding: 0;
         /* 清除内边距 */
         margin: 0;
         /* 清除外边距 */
     }
 </style>

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

2.ps基本操作

切图工作都是在ps里面完成的。

  • 打开图片

  • Ctrl+R 可以打开标尺,或者视图——>标尺

3.综合案例

案例1:产品模块

 <style>
    * {
        padding: 0;
        margin: 0;
    }

    a {
        color: #333;
        text-decoration: none;
    }

    body {
        background-color: #f5f5f5;
    }

    .box {
        width: 298px;
        height: 415px;
        background-color: #fff;
        /* 让块级的盒子水平居中 */
        margin: 100px auto;
        overflow: hidden;
    }

    .box img {
        width: 100%;
    }

    .box p {
        height: 70px;
        font-size: 14px;
        /* 因为这个段落没有width属性 所以padding不会撑开盒子的宽度 */
        padding: 0 28px;
        margin-top: 30px;


    }

    .box .from {
        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;
        margin-top: 15px;
        /* font-weight: normal; */
        font-weight: 400;

    }

    .info span {
        color: #ff6700;
    }

    .info strong {
        color: #ede4e0;
        margin-left: 20px;
        margin-right: 7px;
    }
</style>

<body>
    <div class="box">
        <div class="img"><a href="#"><img src="../images/img.jpg"></a></div>
        <p class="comment">快递牛,整体不错蓝牙可以说秒连。红米给力</p>
        <div class="from">来自于117384232的评价</div>
        <div class="info">
            <h4><a href="#">Redmi AirDots真我无线蓝... </a></h4>
            <strong>|</strong>
            <span> 9.9元</span>
        </div>
    </div>
</body>

总结:

  • 标签是有语义的,合理的使用标签。比如产品标签 就用h,大量文字段就用p

  • 类名就是给每一个盒子起了一个名字,可以更好的找到这个盒子,选取盒子更容易,后期维护也方便。

  • margin padding,大多数情况下可以混用,根据实际情况来选择(实际开发中,有时候用padding需要先设置盒子,然后再设置边距,需要计算,用margin会方便一些,反之也是)

  • 多运用辅助工具

案例2:快报模块

<style>
    * {
        padding: 0;
        margin: 0;
    }

    .box {
        width: 248px;
        height: 163px;
        margin: 100px auto;
        border: 1px solid #cccccc;
        overflow: hidden;
    }

    li {
        list-style: none;
    }

    .box h4 {
        line-height: 32px;
        padding-left: 15px;
        display: block;
        height: 32px;
        border-bottom: 1px dotted #cccccc;
        font-weight: 400;
        font-size: 14px;
        color: #333;
    }

    .box .info {
        margin-top: 7px;
    }

    .box ul li {
        /* 行高是从上一行下沿量到下一行下沿 */
        line-height: 23px;
        padding-left: 20px;
        font-size: 12px;
    }

    .box .info a {
        text-decoration: none;
        color: #666;
    }

    .box .info a:hover {
        text-decoration: underline;
    }
</style>

<body>
    <div class="box">
        <h4 class="title">品优购快报</h4>
        <ul class="info">
            <li><a href="#">【特惠】爆款耳机5折秒</a></li>
            <li><a href="#">【特惠】母亲节,健康好礼</a></li>
            <li><a href="#">【特惠】爆款耳机5折秒</a></li>
            <li><a href="#">【特惠】9.9元洗100张照片</a></li>
            <li><a href="#">【特惠】长虹智能空调立省1000</a></li>
        </ul>
    </div>
</body>

4.圆角边框(重点)

在CSS3中,新增了圆角边框的样式,这样我们的盒子就可以变圆角的了。

语法:

border-radius:length;

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

  • 参数值可以为数值或百分比的形式

  • 如果是正方形,想要设置成一个圆,把数值修改为高度或者宽度的一半即可,或者直接写为50%

  • 如果是个矩形,设置为高度的一半就可以做

  • 该属性是一个简写属性,可以跟四个值,分别代表左上角、右上角、右下角、左下角(顺时针);也可以跟两个数值(左上右下、右上左下对角线)

  • 分开写:border-top-left-radius、border-top-right-radius、border-bottom-left-radius、border-bottom-left-radius

  1. 圆形的做法,将radius改为height的一半,或者用50%

    <style>
        div {
            height: 200px;
            width: 200px;
            background-color: pink;
            /* border-radius: 100px; */
            /* 50% 就是宽度和高度的一半等价于100px */
            border-radius: 50%;
        }
    </style>

5.盒子阴影(重点)

CSS3中新增了盒子阴影,我们可以使用box-shadow属性为盒子添加阴影。

语法:

box-shadow:h-shadow v-shadow blur spread color inset;

注:horizontal-水平的、vertical-垂直的、blur-变得模糊不清、spread-区域、inset-嵌入物

描述
h-shadow、offset-x阴影的水平偏移量。正数向右偏移,负数向左偏移。
v-shadow、offset-y阴影的垂直偏移量。正数向下偏移,负数向上偏移。
blur可选。阴影模糊距离,不能取负数。
spread可选。阴影大小
color可选。阴影的颜色
inset可选。表示添加内阴影,默认为外阴影

注:

  1. 默认的是外阴影(outset),但是不用写,否则会导致阴影无效

  2. 盒子阴影不占用空间,不会影响其他盒子排列。

鼠标经过的阴影特效:

<style>
    div {
        height: 300px;
        width: 300px;
        background-color: pink;
    }

    div:hover {
        box-shadow: 10px 10px 20px 20px rgba(0, 0, 0, .3);
    }
</style>

6.文字阴影

语法:

text-shadow:h-shadow v-shadow blur color;

描述
h-shadow、offset-x阴影的水平偏移量。正数向右偏移,负数向左偏移。
v-shadow、offset-y阴影的垂直偏移量。正数向下偏移,负数向上偏移。
blur可选。阴影模糊距离,不能取负数。
color可选。阴影的颜色
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值