常规流布局(补充)——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

相关文章

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

TP-Link PDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务

《TP-LinkPDDNS服将于务6月30日正式停运:用户需转向第三方DDNS服务》近期,路由器制造巨头普联(TP-Link)在用户群体中引发了一系列重要变动,上个月,公司发出了一则通知,明确要求所... 路由器厂商普联(TP-Link)上个月发布公告要求所有用户必须完成实名认证后才能继续使用普联提供的 D

解决JavaWeb-file.isDirectory()遇到的坑问题

《解决JavaWeb-file.isDirectory()遇到的坑问题》JavaWeb开发中,使用`file.isDirectory()`判断路径是否为文件夹时,需要特别注意:该方法只能判断已存在的文... 目录Jahttp://www.chinasem.cnvaWeb-file.isDirectory()遇

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

JavaWeb-WebSocket浏览器服务器双向通信方式

《JavaWeb-WebSocket浏览器服务器双向通信方式》文章介绍了WebSocket协议的工作原理和应用场景,包括与HTTP的对比,接着,详细介绍了如何在Java中使用WebSocket,包括配... 目录一、概述二、入门2.1 POM依赖2.2 编写配置类2.3 编写WebSocket服务2.4 浏

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,

使用DeepSeek API 结合VSCode提升开发效率

《使用DeepSeekAPI结合VSCode提升开发效率》:本文主要介绍DeepSeekAPI与VisualStudioCode(VSCode)结合使用,以提升软件开发效率,具有一定的参考价值... 目录引言准备工作安装必要的 VSCode 扩展配置 DeepSeek API1. 创建 API 请求文件2.

基于Python开发电脑定时关机工具

《基于Python开发电脑定时关机工具》这篇文章主要为大家详细介绍了如何基于Python开发一个电脑定时关机工具,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 简介2. 运行效果3. 相关源码1. 简介这个程序就像一个“忠实的管家”,帮你按时关掉电脑,而且全程不需要你多做

Spring常见错误之Web嵌套对象校验失效解决办法

《Spring常见错误之Web嵌套对象校验失效解决办法》:本文主要介绍Spring常见错误之Web嵌套对象校验失效解决的相关资料,通过在Phone对象上添加@Valid注解,问题得以解决,需要的朋... 目录问题复现案例解析问题修正总结  问题复现当开发一个学籍管理系统时,我们会提供了一个 API 接口去