HTML和CSS(一)

盒子模型

在一个文档中,每个元素都被表示为一个矩形的盒子。 确定这些盒子的尺寸, 属性(像它的颜色,背景,边框方面)和位置是渲染引擎的目标。

在 CSS 中,使用标准盒模型描述这些矩形盒子中的每一个。 这个模型描述了元素所占空间的内容。 每个盒子有四个边:

  • 外边距边(margin),
  • 边框边(border),
  • 内填充边(padding)
  • 与内容边(content)。

margin 的叠加

只有普通文档流中块框的垂直外边距才会发生外边距叠加。 行内框、 浮动框或绝对定位框之间的外边距不会叠加 外边距(margin)的高度等于两个发生叠加的外边距的高度中的较大者。

例 1

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>
    <div class="a">a</div>
    <div class="b">b</div>
  </head>
  <body>
    <style>
      .a {
        width: 100px;
        height: 100px;
        background-color: red;
        margin-bottom: 10px;
      }
      .b {
        width: 100px;
        height: 100px;
        background-color: blue;
        margin-top: 20px;
      }
    </style>
  </body>
</html>

盒模型计算

盒模型的值

  1. content-box(默认)
  2. padding-box (并不是标准 CSS 规范中的值,所以在实际应用中不会生效。)
  3. border-box (项目中一般设置的)

例 2

html 复制代码
<head>
    <div class="content-box">
        contentBox
    </div>
    <div class="padding-box">
        paddingBox
    </div>
    <div class="border-box">
        borderBox
    </div class="padding-box">
</head>

<body>
    <style>
        .content-box {
            width: 100px;
            height: 100px;
            background-color: red;
            box-sizing: content-box;
            border: 1px solid black;
            padding: 1px;
        }

        .border-box {
            width: 100px;
            height: 100px;
            background-color: blue;
            box-sizing: border-box;
            border: 2px solid pink;
            padding: 2px;
        }

        .padding-box {
            width: 100px;
            height: 100px;
            background-color: green;
            box-sizing: padding-box;
            border: 3px solid yellow;
            padding: 3px;
        }
    </style>

</body>

</html>

元素居中

  1. 使用 inline-block
md 复制代码
在块状元素 parent 内添加了另外一个块状元素 child
将 child 设置 display: inline-block,同时配合 parent 设置 text-align: center,就可以设置 child 在 parent 内横向居中
将 parent 的 height 和 line-height 设置相等,就可以轻松实现 child 在 parent 内纵向居中啦

position 和 z-index

CSS 的 position 和 z-index 有关

文档流

  1. 普通流(正常文档流):在 HTML 里面的写法就是从上到下,从左到右的排版布局 => (position: static)
    • 直接添加 left,top 等定位是无效的
  2. position: relative: 保持原有文档流,但相对本身的原始位置 发生位移,且占空间
    • 会溢出父元素,撑开整个页面:此时给父元素设置 overflow: hidden;则可以隐藏溢出部分 (超出并不会有滚动条)

3. position: absolute : 用于脱离文档流(不占位) * 定位是相对于static定位以外的第一个父元素进行定位 * 当absolute的父元素position为static,则会继续往上查找,直到找到一个为relative/absolute/fixed的父元素作为定位参照物 * 都是static定位,则相对于文档document进行定位 * 未设置定位的absolute元素,其定位与其原本位置(position=static)相同

z-index

  • z-index只能在position属性值为relative/absolute/fixed的元素上有效
  • 当向上追溯找不到含有z-index值的父元素的情况下,则可以视为自由的z-index元素
  • 自由的z-index元素可以与其他自由的定位元素或者父元素的同级兄弟定位元素来比较z-index的值
  • z-index值只决定同一父元素中的同级子元素的堆叠顺序
  • 不同父元素中的子元素由元素在文档中的先后位置决定,后出现的会在上面。

总结:

重新学习了一遍盒模型,对文档流和层级有了更加清晰的认识。

相关推荐
腾讯TNTWeb前端团队6 分钟前
helux v5 发布了,像pinia一样优雅地管理你的react状态吧
前端·javascript·react.js
范文杰3 小时前
AI 时代如何更高效开发前端组件?21st.dev 给了一种答案
前端·ai编程
拉不动的猪4 小时前
刷刷题50(常见的js数据通信与渲染问题)
前端·javascript·面试
拉不动的猪4 小时前
JS多线程Webworks中的几种实战场景演示
前端·javascript·面试
FreeCultureBoy4 小时前
macOS 命令行 原生挂载 webdav 方法
前端
uhakadotcom5 小时前
Astro 框架:快速构建内容驱动型网站的利器
前端·javascript·面试
uhakadotcom5 小时前
了解Nest.js和Next.js:如何选择合适的框架
前端·javascript·面试
uhakadotcom5 小时前
React与Next.js:基础知识及应用场景
前端·面试·github
uhakadotcom5 小时前
Remix 框架:性能与易用性的完美结合
前端·javascript·面试
uhakadotcom5 小时前
Node.js 包管理器:npm vs pnpm
前端·javascript·面试