”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 使用 CSS 网格和 Flexbox 的响应式网页设计

使用 CSS 网格和 Flexbox 的响应式网页设计

发布于2024-08-07
浏览:807

Responsive Web Design with CSS Grid and Flexbox

使用 CSS 网格和 Flexbox 的响应式网页设计

响应式网页设计是一种开发网站的方法,使其可以在各种设备和屏幕尺寸上正常运行。响应式设计不必为不同设备创建多个版本的网站,而是使用灵活的网格和布局、媒体查询和流畅的图像来跨所有平台提供更好的用户体验。

为什么响应式网页设计很重要?

随着世界各地越来越多的人使用手机和平板电脑浏览互联网,拥有响应式网站不再是一种选择,而是一种必需。响应式设计允许消费者无缝访问内容,无论他们使用什么设备,从而提高可用性。它还通过确保内容在视觉上连贯且易于跨设备阅读来改善用户体验,这可以减少挫败感并鼓励互动。此外,响应式设计可以保证网站面向未来,让它们适应新设备,而无需进行大量重新设计。

今天,我们将了解响应式网页设计的基础知识,并特别关注两种强大的 CSS 技术:Flexbox 和 CSS Grid。我们将使用带有彩色框和数字的简单网站来展示这些布局如何适应不同的屏幕尺寸。

响应式网页设计简史

自互联网早期以来,响应式网页设计已经发生了很大变化。媒体查询,根据设备特征(例如屏幕尺寸、分辨率和方向)应用样式。 2000 年代初推出,Flexbox 于 2012 年推出,CSS Grid 于 2017 年采用。这些创新使设计人员能够在多种不同设备上创建适应性布局,为用户提供更好的体验。

使用 CSS 网格和 Flexbox 创建响应式布局

现在,让我们看一些实际示例,了解 Flexbox 和 CSS Grid 的工作原理。

响应式网格布局:颜色网格

我们将使用 CSS 网格创建一个简单的布局。

网格布局的 HTML:



    Color Grid
1
2
3
4
5
6

HTML:

  • HTML 标记创建一个响应式容器(网格容器)和具有不同数字和背景颜色的彩色框(网格项)。视口元标记允许布局在不同设备上缩放。

网格布局的 CSS:

/* styles.css */
body {
    margin: 0;
    font-family: Arial, sans-serif;
    background: #f0f0f0;
}

.grid-container {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(100px, 1fr));
    gap: 10px;
    padding: 20px;
}

.grid-item {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100px;
    color: #fff;
    font-size: 2em;
    border-radius: 8px;
}

CSS:

  • 网格布局的 CSS 使用不同的网格属性来提高响应速度。显示方式:网格;声明将带有 grid-container 类的元素设置为网格容器,以便我们可以利用网格提供的所有功能。网格模板列:repeat(auto-fit, minmax(100px, 1fr));属性定义网格中列的结构:它根据可用空间自动调整列数,每列的最小宽度为 100 像素,最大为可用空间的 1 分数 (1fr)。这种设计允许网格适应不同的屏幕尺寸,这样网格项目就不会溢出或产生难看的间隙。间隙:10px;属性对网格项应用一致的间距。最后,我们使用 display: flex; 堆叠 grid-item 元素。并将其内容居中 justify-content: center;和对齐项目:居中。这样,每个项目都组织良好且平衡。

响应式网页设计示例:网格布局

此网格布局使用:

  1. 动态列数:网格自动调整列数以适应视口宽度,项目最小为 100px。
  2. 灵活的尺寸调整:自动调整让盒子在需要时重新排列和重新排列,让一切看起来更有条理。
  3. 媒体查询:虽然实际上没有写在这里,但网格元素在不同屏幕尺寸下的行为方式通过使用响应式网格属性演示了媒体查询的概念。

响应式 Flexbox 布局:颜色行

接下来,让我们使用 Flexbox 创建一排简单的彩色框。

Flexbox 布局的 HTML:



    Color Row
1
2
3
4

HTML:

  • 与网格示例类似,此处的 HTML 创建一个弹性容器,其中包含显示彩色数字的弹性项目框。

Flexbox 布局的 CSS:

/* styles.css */
body {
    margin: 0;
    font-family: Arial, sans-serif;
    background: #f5f5f5;
}

.flex-container {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    padding: 20px;
    gap: 10px;
}

.flex-item {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100px;
    width: 100px;
    color: #fff;
    font-size: 2em;
    border-radius: 8px;
}

CSS:
这里的 CSS 使用 Flexbox 属性来创建适应各种屏幕尺寸的响应式布局。显示屏:柔性; .flex-container 中提供其子元素或(flex 项目)Flexbox 功能。 flex-wrap:包裹;如果超过容器的宽度,属性允许项目流到多行。调整内容:居中;属性将弹性项目沿主轴居中,因此无论项目数量如何,都有一个平衡的布局。间隙:10px;属性在项目之间引入了统一的间距,从而改善了整体组织。每个.flex-item也是一个flex容器,使用display: flex;允许进一步对齐其内部内容,使用 justify-content: center; 垂直和水平居中;和对齐项目:中心;。高度固定尺寸:100px;宽度:100px;提供一致性,而这些属性的组合使布局具有令人愉悦的外观,同时适应不同设备的需求。

响应式网页设计示例:Flexbox 布局

这个弹性盒布局展示了几个响应式设计特征。

  1. Flex Wrapping:flex-wrap:wrap;属性使框在无法放入行时移动到下一行,以适应不同的视口宽度。
  2. 居中项目:无论屏幕大小如何,项目都保持居中,从而改善整体呈现效果。
  3. 固定尺寸:盒子具有特定的尺寸,但它们会根据可用空间进行包裹和重新调整,从而实现响应式布局。

CSS 网格和 Flexbox 的比较

说到 CSS 布局设计,Grid 和 Flexbox 都是不错的选择,但它们有不同的用途。 CSS 网格是一种二维布局系统,允许您创建具有行和列的复杂网格结构,非常适合需要精确控制两个维度的布局,例如在 Web 应用程序或仪表板中。另一方面,Flexbox 是一种一维布局模型,最适合沿单个轴(水平或垂直)分配空间,使其非常适合更简单的布局或按钮或导航菜单等较小的组件。虽然您可能会选择 Grid 来实现全面的、结构化的布局,其中元素需要在两个轴上对齐,但 Flexbox 将是您需要响应内容大小的自适应、流畅的布局的首选。最后,您的选择应该取决于您项目的具体需求;通常,将两者互补地一起使用可以给您带来最佳结果。

结论

借助 CSS Grid 和 Flexbox,您可以创建在任何设备上看起来都很棒的自适应布局。这些示例说明了实现动态设计是多么简单。

现在轮到你了!尝试这些技术,修改颜色和布局设置,看看创建有趣且响应式的设计有多么简单。
``
来源:
https://www.w3schools.com/css/css3_flexbox.asp
https://www.w3schools.com/css/css_grid.asp
https://developer.mozilla.org/en-US/docs/Learn/CSS/CSS_layout
https://kinsta.com/blog/responsive-web-design/#4-flexbox-layout
https://css-tricks.com/snippets/css/a-guide-to-flexbox/
https://css-tricks.com/snippets/css/complete-guide-grid/
https://blog.logrocket.com/css-flexbox-vs-css-grid/#:~:text=对于主要布局样式,在处理行时很有帮助。

版本声明 本文转载于:https://dev.to/wendyver/responsive-web-design-with-css-grid-and-flexbox-2gio?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 网站 HTML 代码
    网站 HTML 代码
    我一直在尝试建立一个与航空公司相关的网站。我只是想确认我是否可以使用人工智能生成代码来生成整个网站。 HTML 网站是否兼容博客,或者我应该使用 JavaScript?这是我用作演示的代码。 <!DOCTYPE html> <html lang="en">[](url) &l...
    编程 发布于2024-11-05
  • 像程序员一样思考:学习 Java 基础知识
    像程序员一样思考:学习 Java 基础知识
    本文介绍了 Java 编程的基本概念和结构。它首先介绍了变量和数据类型,然后讨论了操作符和表达式,以及控制流流程。其次,它解释了方法和类,然后介绍了输入和输出操作。最后,本文通过一个工资计算器的实际示例展示了这些概念的应用。像程序员一样思考:掌握 Java 基础1. 变量和数据类型Java 使用变量...
    编程 发布于2024-11-05
  • PHP GD 可以比较两个图像的相似性吗?
    PHP GD 可以比较两个图像的相似性吗?
    PHP GD 可以确定两个图像的相似度吗?正在考虑的问题询问是否可以使用以下命令确定两个图像是否相同PHP GD 通过比较它们的差异。这需要获取两个图像之间的差异并确定它是否完全由白色(或任何统一的颜色)组成。根据提供的答案,散列函数(如其他响应所建议的那样)不适用于此语境。比较必须涉及图像内容而不...
    编程 发布于2024-11-05
  • 使用这些键编写高级测试(JavaScript 中的测试需求)
    使用这些键编写高级测试(JavaScript 中的测试需求)
    在本文中,您将学习每个高级开发人员都应该了解的 12 个测试最佳实践。您将看到 Kent Beck 的文章“Test Desiderata”的真实 JavaScript 示例,因为他的文章是用 Ruby 编写的。 这些属性旨在帮助您编写更好的测试。了解它们还可以帮助您在下一次工作面试中取得好成绩。 ...
    编程 发布于2024-11-05
  • 通过将 matlab/octave 算法移植到 C 来实现 AEC 的最佳解决方案
    通过将 matlab/octave 算法移植到 C 来实现 AEC 的最佳解决方案
    完毕!对自己有点印象。 我们的产品需要回声消除功能,确定了三种可能的技术方案, 1)利用MCU检测audio out和audio in的音频信号,编写算法计算两侧声音信号的强度,根据audio out和audio in的强弱在两个通道之间进行可选的切换,实现半双工通话效果,但现在市场上都是全双工通话...
    编程 发布于2024-11-05
  • 逐步构建网页:探索 HTML 中的结构和元素
    逐步构建网页:探索 HTML 中的结构和元素
    ?今天标志着我软件开发之旅的关键一步! ?我编写了第一行代码,深入研究了 HTML 的本质。涵盖的元素和标签。昨天,我探索了构建网站的拳击技术,今天我通过创建页眉、页脚和内容区域等部分将其付诸实践。我还添加了各种 HTML 元素,包括图像元素和链接元素,甚至尝试在单页网站上进行内部链接。看到这些部分...
    编程 发布于2024-11-05
  • 项目创意不一定是独特的:原因如下
    项目创意不一定是独特的:原因如下
    在创新领域,存在一个常见的误解,即项目创意需要具有开创性或完全独特才有价值。然而,事实并非如此。我们今天使用的许多成功产品与其竞争对手共享一组核心功能。让他们与众不同的不一定是想法,而是他们如何执行它、适应用户需求以及在关键领域进行创新。 通讯应用案例:相似但不同 让我们考虑一下 M...
    编程 发布于2024-11-05
  • HackTheBox - Writeup 社论 [已退休]
    HackTheBox - Writeup 社论 [已退休]
    Neste writeup iremos explorar uma máquina easy linux chamada Editorial. Esta máquina explora as seguintes vulnerabilidades e técnicas de exploração: S...
    编程 发布于2024-11-05
  • 强大的 JavaScript 技术可提升您的编码技能
    强大的 JavaScript 技术可提升您的编码技能
    JavaScript is constantly evolving, and mastering the language is key to writing cleaner and more efficient code. ?✨ Whether you’re just getting starte...
    编程 发布于2024-11-05
  • 如何在 ReactJS 中创建可重用的 Button 组件
    如何在 ReactJS 中创建可重用的 Button 组件
    按钮无疑是任何 React 应用程序中重要的 UI 组件,按钮可能用于提交表单或打开新页面等场景。您可以在 React.js 中构建可重用的按钮组件,您可以在应用程序的不同部分中使用它们。因此,维护您的应用程序将变得更加简单,并且您的代码将保持 DRY(不要重复自己)。 您必须首先在组件文件夹中创建...
    编程 发布于2024-11-05
  • 如何在 Apache HttpClient 4 中实现抢占式基本身份验证?
    如何在 Apache HttpClient 4 中实现抢占式基本身份验证?
    使用 Apache HttpClient 4 简化抢占式基本身份验证虽然 Apache HttpClient 4 已经取代了早期版本中的抢占式身份验证方法,但它提供了替代方法以实现相同的功能。对于寻求直接抢占式基本身份验证方法的开发人员,本文探讨了一种简化方法。为了避免向每个请求手动添加 Basic...
    编程 发布于2024-11-05
  • 异常处理
    异常处理
    异常是运行时发生的错误。 Java 中的异常处理子系统允许您以结构化和受控的方式处理错误。 Java为异常处理提供了易于使用且灵活的支持。 主要优点是错误处理代码的自动化,以前必须手动完成。 在旧语言中,需要手动检查方法返回的错误码,既繁琐又容易出错。 异常处理通过在发生错误时自动执行代码块(异常...
    编程 发布于2024-11-05
  • 如何在不使用“dangerouslySetInnerHTML”的情况下安全地在 React 中渲染原始 HTML?
    如何在不使用“dangerouslySetInnerHTML”的情况下安全地在 React 中渲染原始 HTML?
    使用更安全的方法在 React 中渲染原始 HTML在 React 中,您现在可以使用更安全的方法渲染原始 HTML,避免使用危险的SetInnerHTML 。这里有四个选项:1。 Unicode 编码使用 Unicode 字符表示 UTF-8 编码文件中的 HTML 实体:<div>{...
    编程 发布于2024-11-05
  • PHP 死了吗?不,它正在蓬勃发展
    PHP 死了吗?不,它正在蓬勃发展
    PHP 是一种不断受到批评但仍在蓬勃发展的编程语言。 使用率:根据 W3Techs 的数据,截至 2024 年 8 月,全球 75.9% 的网站仍在使用 PHP,其中 43% 的网站基于 WordPress。使用PHP作为开发语言的主流网站中,超过70%包括Facebook、微软、维基百科、Mozi...
    编程 发布于2024-11-05
  • PgQueuer:将 PostgreSQL 转变为强大的作业队列
    PgQueuer:将 PostgreSQL 转变为强大的作业队列
    PgQueuer 简介:使用 PostgreSQL 实现高效作业队列 社区开发者您好! 我很高兴分享一个项目,我相信该项目可以显着简化开发人员在使用 PostgreSQL 数据库时处理作业队列的方式。 PgQueuer,这是一个 Python 库,旨在利用 PostgreSQL 的...
    编程 发布于2024-11-05

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3