CSS”包装盒“--盒模型——WEB开发系列17

2024-08-24 03:12

本文主要是介绍CSS”包装盒“--盒模型——WEB开发系列17,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CSS 盒模型(Box Model)在 CSS 中,所有的元素都被一个个的“盒子”包围着,理解这些“盒子”的基本原理,是我们使用 CSS 实现准确布局、处理元素排列的关键。


一、什么是 CSS 盒模型?

CSS 盒模型是指每个 HTML 元素可以被看作一个矩形盒子,这个盒子由多个区域组成。这些区域包括内容区域、内边距(padding)、边框(border)和外边距(margin)。


盒模型的组成部分

  1. 内容区域(Content):包含元素的实际内容,如文本、图片等。内容区域的大小由 ​​width​​ 和 ​​height​​ 属性设置。
  2. 内边距(Padding):内容区域与边框之间的空间,内边距可以使内容与边框之间保持一定的距离。通过 ​​padding​​ 属性设置,四个方向的内边距可以单独定义或使用简写属性一次性设置。
  3. 边框(Border):围绕内边距和内容区域的边框,边框的样式、宽度和颜色可以通过 ​​border​​ 属性设置。
  4. 外边距(Margin):元素与相邻元素之间的空间,外边距用于调整元素的位置。通过 ​​margin​​ 属性设置,同样支持单独定义每个方向或使用简写属性。

二、区块盒子与行内盒子

在 CSS 中,元素的显示类型决定了其盒模型的表现形式。主要有两种显示类型:区块盒子(Block-level Box)和行内盒子(Inline Box)。


区块盒子(Block-level Box)

区块盒子元素通常会从新的一行开始,占据其父容器的整个宽度。例如:​​<div>​​, ​​<p>​​, ​​<h1>​​ 等。它们具有以下特性:

  • 宽度:默认情况下,宽度自动扩展以填满父容器的宽度。可以通过 ​​width​​ 属性调整。
  • 高度:可以通过 ​​height​​ 属性设置高度。
  • 内边距、边框、外边距:这些属性的设置影响元素的总高度和总宽度。

示例代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Block-Level Box</title><style>.block-box {width: 300px;height: 150px;padding: 20px;border: 5px solid blue;margin: 30px;background-color: lightgray;}</style>
</head>
<body><div class="block-box">这是一个区块盒子元素</div>
</body>
</html>


行内盒子(Inline Box)

行内盒子元素不会从新的一行开始,只占据其内容所需的宽度。常见的行内元素:​​<span>​​, ​​<a>​​, ​​<img>​​ 等。其主要特征是:

  • 宽度和高度:无法通过 ​​width​​ 和 ​​height​​ 属性设置,元素的宽度和高度由其内容决定。
  • 内边距和边框:影响行内元素的周围空间,但不会改变其所在行的高度。
  • 外边距:可以设置,但效果有限,可能不会影响布局的整体结构。

示例代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Inline Box</title><style>.inline-box {padding: 10px;border: 2px solid green;background-color: lightblue;}</style>
</head>
<body><p>这是一个行内盒子元素 <span class="inline-box">这是行内元素</span> 后面的内容继续。</p>
</body>
</html>


三、外部显示类型(Display Types)

CSS 提供了不同的显示类型来控制元素的显示行为。主要的显示类型包括:


​block​

区块级元素,通常从新的一行开始,并且占据父容器的整个宽度。适用于 ​​div​​, ​​p​​ 等。

示例代码

<style>.block-element {display: block;}
</style>

​inline​

行内元素,不会从新的一行开始,其宽度由内容决定。适用于 ​​span​​, ​​a​​ 等。

示例代码

<style>.inline-element {display: inline;}
</style>

​inline-block​

结合了区块级和行内元素的特性,元素既能设置宽度和高度,又能在行内显示。适用于需要控制尺寸的行内元素,如图标和按钮。

示例代码

<style>.inline-block-element {display: inline-block;width: 100px;height: 50px;background-color: lightcoral;text-align: center;line-height: 50px;color: white;}
</style>

​none​

元素不显示并且不占据空间。

示例代码

<style>.hidden-element {display: none;}
</style>

四、内部显示类型(Box-Sizing)

CSS3 引入了 ​​box-sizing​​​ 属性,使得开发者可以控制盒模型的尺寸计算方式。主要的值包括:


​content-box​

这是默认值,宽度和高度只包括内容区域,不包括内边距、边框和外边距。

示例代码

<style>.content-box-element {box-sizing: content-box;width: 200px;padding: 10px;border: 5px solid black;}
</style>

​border-box​

宽度和高度包括内容区域、内边距和边框,外边距不包括在内。

示例代码

<style>.border-box-element {box-sizing: border-box;width: 200px;padding: 10px;border: 5px solid black;}
</style>

五、不同显示类型的例子

区块盒子示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Block-Level Example</title><style>.block-example {display: block;width: 300px;padding: 20px;border: 5px solid red;margin: 30px;}</style>
</head>
<body><div class="block-example">区块盒子示例</div>
</body>
</html>


行内盒子示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Inline Example</title><style>.inline-example {display: inline;padding: 5px;border: 2px solid blue;background-color: lightgreen;}</style>
</head>
<body><p>这是行内盒子 <span class="inline-example">示例</span> 在行内显示。</p>
</body>
</html>


​inline-block​​ 示例

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Inline-Block Example</title><style>.inline-block-example {display: inline-block;width: 150px;height: 100px;padding: 10px;border: 3px solid purple;background-color: lightyellow;text-align: center;line-height: 100px;}</style>
</head>
<body><div class="inline-block-example">行内块级示例</div><div class="inline-block-example">另一个示例</div>
</body>
</html>


六、玩转盒模型

理解盒模型的各个组成部分后,可以更好地控制网页元素的布局。

外边距(Margin)

<style>.margin-example {margin: 20px;background-color: lightblue;}
</style>

内边距(Padding)

<style>.padding-example {padding: 15px;background-color: lightgreen;}
</style>

边框(Border)

<style>.border-example {border: 2px solid red;background-color: lightcoral;}
</style>

七、盒子模型和行内盒子

对于行内盒子,通过 ​​display: inline-block​​ 可以同时享有行内元素和区块元素的优点。例如,图标和按钮通常使用 ​​inline-block​​ 显示,以便能够设置尺寸并且与其他行内元素在同一行内显示。

示例代码

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Inline-Block with Box Model</title><style>.inline-block-box {display: inline-block;width: 100px;height: 100px;padding: 10px;border: 5px solid black;margin: 10px;background-color: lightblue;text-align: center;line-height: 80px;}</style>
</head>
<body><div class="inline-block-box">Box 1</div><div class="inline-block-box">Box 2</div><div class="inline-block-box">Box 3</div>
</body>
</html>


这篇关于CSS”包装盒“--盒模型——WEB开发系列17的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1101284

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Python基于wxPython和FFmpeg开发一个视频标签工具

《Python基于wxPython和FFmpeg开发一个视频标签工具》在当今数字媒体时代,视频内容的管理和标记变得越来越重要,无论是研究人员需要对实验视频进行时间点标记,还是个人用户希望对家庭视频进行... 目录引言1. 应用概述2. 技术栈分析2.1 核心库和模块2.2 wxpython作为GUI选择的优

JSON Web Token在登陆中的使用过程

《JSONWebToken在登陆中的使用过程》:本文主要介绍JSONWebToken在登陆中的使用过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录JWT 介绍微服务架构中的 JWT 使用结合微服务网关的 JWT 验证1. 用户登录,生成 JWT2. 自定义过滤

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

一文教你如何将maven项目转成web项目

《一文教你如何将maven项目转成web项目》在软件开发过程中,有时我们需要将一个普通的Maven项目转换为Web项目,以便能够部署到Web容器中运行,本文将详细介绍如何通过简单的步骤完成这一转换过程... 目录准备工作步骤一:修改​​pom.XML​​1.1 添加​​packaging​​标签1.2 添加

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

利用Python开发Markdown表格结构转换为Excel工具

《利用Python开发Markdown表格结构转换为Excel工具》在数据管理和文档编写过程中,我们经常使用Markdown来记录表格数据,但它没有Excel使用方便,所以本文将使用Python编写一... 目录1.完整代码2. 项目概述3. 代码解析3.1 依赖库3.2 GUI 设计3.3 解析 Mark

Vue中组件之间传值的六种方式(完整版)

《Vue中组件之间传值的六种方式(完整版)》组件是vue.js最强大的功能之一,而组件实例的作用域是相互独立的,这就意味着不同组件之间的数据无法相互引用,针对不同的使用场景,如何选择行之有效的通信方式... 目录前言方法一、props/$emit1.父组件向子组件传值2.子组件向父组件传值(通过事件形式)方

css中的 vertical-align与line-height作用详解

《css中的vertical-align与line-height作用详解》:本文主要介绍了CSS中的`vertical-align`和`line-height`属性,包括它们的作用、适用元素、属性值、常见使用场景、常见问题及解决方案,详细内容请阅读本文,希望能对你有所帮助... 目录vertical-ali

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件