• CSS盒子模型(上)


    🍓个人主页:bit.. 

    🍒系列专栏:Linux(Ubuntu)入门必看   C语言刷题      数据结构与算法  HTML和CSS3

    目录

    1.盒子模型

    1.2盒子模型(Box Model)组成

    1.3边框(border)

    1.4 表格的细线边框

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

    1.6内边距(padding)

    1.7外边距(margin)

    1.8 外边距的合并

    1.9清除内外边距

    盒子模型的作用:

    • 能够准确阐述盒子模型的四个组成部分
    • 能够利用边框复合写法给元素添加边框
    • 能够计算盒子的实际大小
    • 能够利用盒子模型布局模块案例
    • 能够给盒子设置图角边框
    • 能够给盒子添加阴影
    • 能够给文字添加阴影

    1.盒子模型

    三大核心:盒子模型 浮动 定位 

    1.1看透网页布局的本质

    网页布局过程:

    1. 先准备号相关的网页元素,网页元素基本都是盒子box。
    2. 利用CSS设置好盒子样式,然后摆放到相应位置。
    3. 王盒子里面装内容

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

    1.2盒子模型(Box Model)组成

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

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

    52b26c61d8664127bffd214bd5ebef11.png

    1.3边框(border)

    border 可以设置元素的边框,边框有三个部分组成:

    边框宽度(粗细)   边框样式     边框颜色

    语法:

    border: border-width  // border-style //border-color

    属性作用
    border-width定义边框粗细,单位是px
    border-style边框样式
    border-color边框颜色

    border-style:  solid 实线边框   dashed 虚线边框   dotted 点式虚线边框

    边框的简写:

            border: 1px solid red;      没有顺序

    边框分开写法:

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

    1.4 表格的细线边框

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

    语法: 

            border-collapse: collapse;

    callapse单词是合并的意思。

    border-collapse: collapse; 表示相邻边框合并在一起。

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

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

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

    1.6内边距(padding)

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

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

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

    值的个数表边意思
    padding: 5px;一个值,代表上下左右都有五个像素的边距
    padding: 5px 10px;两个值,代表上下内边距是五个像素,左右边距十个像素
    padding: 5px 10px 20px;三个值,上内行边距五像素,左右边距十像素,下内行边距二十像素
    padding: 5px 10px 20px 30px;四个值 上边距五像素,右边距十像素,下边距二十像素 左边距三十像素 (顺时针)

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

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

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

    解决方案:

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

    1.7外边距(margin)

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

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

    margin简写方式与padding完全一致。

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

    • 盒子必须指定了宽度(width)
    • 盒子左右的外边距都设置为auto

    1.8 外边距的合并

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

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

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

    解决方案:

    尽量只给一个盒子添加margin值

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

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

     

    解决方案:

    • 可以为父元素定义上外边框。border:1px  solid red/transparent
    • 可以为父元素定义上内边距  padding:1px
    • 可以为父元素添加: overflow:hidden 

    还有其他方法:比如浮动,固定,绝对定位的盒子不会有塌陷问题。

    1.9清除内外边距

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

    1. * {
    2. padding: 0;
    3. margin: 0;
    4. }

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

    总结:

    1. 标签都是有语义的,合理的地方要使用合理的标签。比如产品标签就要用 h。大量文字段落就用 p
    2. 类名就是给每个盒子起一个名字,可以更好的找到这个盒子,选取盒子更容易,后期维护更方便。
    3. 对于margin与padding的使用,大部分情况两个可以混用,两者各有优缺点,但是格局实际情况,总是有更简单的方法实现。
  • 相关阅读:
    Proteus + Keil单片机仿真教程(六)多位LED数码管的动态显示
    在线编辑PDF:GcPDF|PDF在线预览GrapeCity Documen PDF
    synchronized:解决死锁的问题
    猿创征文|三维重建领域的开发者工具箱
    【2022年玄武云科技AI算法岗秋招面试记录】
    5分钟搭建图片压缩应用
    规格化浮点数
    零信任实施过程中需要考虑哪些因素
    IC基础——FIFO
    Azure DevOps Server 入门实践与安装部署
  • 原文地址:https://blog.csdn.net/weixin_68773927/article/details/128148381