常规流布局(补充)——WEB开发系列30

2024-09-05 18:20

本文主要是介绍常规流布局(补充)——WEB开发系列30,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

CSS(层叠样式表)作为现代网页设计的基础之一,其布局功能一直是开发者关注的重点。了解CSS常规流布局是掌握网页布局的第一步。


一、什么是常规流布局?

常规流布局(Normal Flow Layout)是CSS布局的基础,也是网页布局的默认方式。在常规流中,所有的元素都按照文档中的顺序依次排列。这种布局方式非常直观,可以帮助我们理解各种布局模式的基础。常规流布局包括块级元素(Block-level Elements)和行内元素(Inline Elements)的布局方式。


块级元素(Block-level Elements)

块级元素是指那些会在新的一行开始显示的元素。这些元素通常会占据父容器的整个宽度,直到遇到下一个块级元素或容器的边缘。常见的块级元素包括 ​​<div>​​、​​<p>​​、​​<h1>​​、​​<section>​​、​​<article>​​ 等。

示例代码:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Block-Level Elements Example</title><style>.block {background-color: lightblue;margin: 10px;padding: 10px;}</style>
</head>
<body><div class="block">这是第一个块级元素</div><div class="block">这是第二个块级元素</div><div class="block">这是第三个块级元素</div>
</body>
</html>

解释:

在这个示例中的三个 ​​div​​ 元素被定义为块级元素。它们每个都在新的一行上显示,具有相同的背景色、边距和内边距。每个 ​​div​​​ 元素都占据了父容器的整个宽度,除非有其他元素阻止其占据更多空间。


行内元素(Inline Elements)

行内元素是在同一行中排列的元素,它们只占据其内容的宽度,不会强制换行。常见的行内元素包括 ​​<span>​​、​​<a>​​、​​<strong>​​、​​<em>​​​ 等。

示例代码:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Inline Elements Example</title><style>.inline {background-color: lightcoral;margin: 5px;padding: 5px;}</style>
</head>
<body><p>这是一个段落,其中包含<span class="inline">行内元素1</span>和<span class="inline">行内元素2</span>的例子。</p>
</body>
</html>

解释:

示例中两个 ​​span​​ 元素被定义为行内元素。它们显示在同一行中,与周围的文本混合在一起。即使这些 ​​span​​​ 元素具有背景色、边距和内边距,它们也不会影响其他行内元素的布局。


二、常规流布局的计算规则

在常规流布局中,元素的排列方式遵循以下规则:

块级元素的排列

  1. 从上到下排列: 块级元素会从上到下排列,每个块级元素的起始位置都会在新的一行上。它们的宽度默认是父容器的全宽。
  2. 宽度和高度: 块级元素的宽度可以被调整,通常是通过 ​​width​​​ 属性设置。默认情况下,高度会根据内容的大小自适应。

行内元素的排列

  1. 从左到右排列: 行内元素会从左到右排列,并在同一行中显示。它们的宽度和高度通常由内容决定。
  2. 行内换行: 当行内元素的总宽度超出父容器的宽度时,会自动换行。

三、实际应用中的常规流布局

在实际应用中,常规流布局经常用于创建简单的页面布局,如文章段落、列表等。以下是一些常见的布局示例:

示例 1:基本页面布局

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Basic Page Layout</title><style>header, footer {background-color: lightgray;padding: 10px;text-align: center;}main {margin: 10px;padding: 10px;}article {background-color: lightyellow;margin: 10px 0;padding: 10px;}</style>
</head>
<body><header>网站标题</header><main><article>第一篇文章</article><article>第二篇文章</article></main><footer>网站底部</footer>
</body>
</html>

解释:

示例展示了一个简单的网页布局,包括头部、主体和底部。​​header​​、​​main​​ 和 ​​footer​​ 都是块级元素,按顺序从上到下排列。​​article​​​ 元素也是块级元素,用于展示文章内容。


示例 2:内联元素的使用

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Inline Elements Usage</title><style>.highlight {background-color: yellow;padding: 2px;}</style>
</head>
<body><p>这是一段包含<span class="highlight">突出显示</span>的文本,展示了行内元素的效果。</p>
</body>
</html>

解释:

示例演示了如何在段落中使用行内元素。​​span​​​ 元素用来突出显示文本,并且不会改变行内文本的布局。

四、常规流布局中的常见问题

在使用常规流布局时,我们可能会遇到一些常见的问题,包括:

  1. 元素溢出: 当元素的内容超出其父容器的宽度时,内容会自动换行或溢出。这可以通过设置合适的宽度或使用 ​​overflow​​ 属性来控制。
  2. 行高不一致: 不同的元素或内容可能导致行高不一致,这通常需要通过设置 ​​line-height​​​ 或调整内边距来解决。

如有表述错误及欠缺之处敬请指正补充。

这篇关于常规流布局(补充)——WEB开发系列30的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

Hadoop企业开发案例调优场景

需求 (1)需求:从1G数据中,统计每个单词出现次数。服务器3台,每台配置4G内存,4核CPU,4线程。 (2)需求分析: 1G / 128m = 8个MapTask;1个ReduceTask;1个mrAppMaster 平均每个节点运行10个 / 3台 ≈ 3个任务(4    3    3) HDFS参数调优 (1)修改:hadoop-env.sh export HDFS_NAMENOD

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

OpenHarmony鸿蒙开发( Beta5.0)无感配网详解

1、简介 无感配网是指在设备联网过程中无需输入热点相关账号信息,即可快速实现设备配网,是一种兼顾高效性、可靠性和安全性的配网方式。 2、配网原理 2.1 通信原理 手机和智能设备之间的信息传递,利用特有的NAN协议实现。利用手机和智能设备之间的WiFi 感知订阅、发布能力,实现了数字管家应用和设备之间的发现。在完成设备间的认证和响应后,即可发送相关配网数据。同时还支持与常规Sof

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

30常用 Maven 命令

Maven 是一个强大的项目管理和构建工具,它广泛用于 Java 项目的依赖管理、构建流程和插件集成。Maven 的命令行工具提供了大量的命令来帮助开发人员管理项目的生命周期、依赖和插件。以下是 常用 Maven 命令的使用场景及其详细解释。 1. mvn clean 使用场景:清理项目的生成目录,通常用于删除项目中自动生成的文件(如 target/ 目录)。共性规律:清理操作

科研绘图系列:R语言扩展物种堆积图(Extended Stacked Barplot)

介绍 R语言的扩展物种堆积图是一种数据可视化工具,它不仅展示了物种的堆积结果,还整合了不同样本分组之间的差异性分析结果。这种图形表示方法能够直观地比较不同物种在各个分组中的显著性差异,为研究者提供了一种有效的数据解读方式。 加载R包 knitr::opts_chunk$set(warning = F, message = F)library(tidyverse)library(phyl

Java Web指的是什么

Java Web指的是使用Java技术进行Web开发的一种方式。Java在Web开发领域有着广泛的应用,主要通过Java EE(Enterprise Edition)平台来实现。  主要特点和技术包括: 1. Servlets和JSP:     Servlets 是Java编写的服务器端程序,用于处理客户端请求和生成动态网页内容。     JSP(JavaServer Pages)