0

0

如何使用CSS Grid实现“大方块左侧,小方块右侧垂直堆叠”的水平布局

霞舞

霞舞

发布时间:2025-11-29 08:29:35

|

614人浏览过

|

来源于php中文网

原创

如何使用CSS Grid实现“大方块左侧,小方块右侧垂直堆叠”的水平布局

本文旨在指导读者如何利用css grid的强大布局能力,将原有的垂直堆叠式“大方块内部包含小方块”结构,高效转换为水平方向的“大方块居左,小方块在右侧垂直堆叠”布局。文章将详细阐述grid属性如grid-template-columns、grid-template-rows和grid-template-areas的应用,并提供优化后的html和css代码示例,旨在帮助开发者掌握复杂的网页布局技巧。

网页设计中,我们经常需要创建各种复杂的布局。当面对一个需要将主内容区域放置在左侧,而辅助内容(例如两个小方块)垂直堆叠在右侧的布局需求时,CSS Grid提供了一种强大且直观的解决方案。本教程将通过一个具体的示例,详细演示如何从一个基于Flexbox的垂直布局,转换为一个利用CSS Grid实现的水平布局。

布局挑战分析

原始布局的需求是:一个较大的“日期网格”容器内部包含一个主内容区域(显示数字),以及一个包含两个小方块的辅助区域。最初的实现方式可能采用Flexbox,将主内容和辅助区域垂直堆叠,辅助区域内部的两个小方块水平并排。

然而,新的需求是:

  1. 保持主内容区域(大方块)的视觉模型不变。
  2. 将主内容区域放置在整个结构的左侧。
  3. 将两个小方块垂直堆叠,并放置在主内容区域的右侧。

这种“主区域占据多行,辅助区域并列且自身堆叠”的布局模式,正是CSS Grid擅长处理的场景。

立即学习前端免费学习笔记(深入)”;

采用CSS Grid进行布局重构

CSS Grid布局(CSS网格布局)是一种二维布局系统,能够同时处理行和列的布局。它允许我们精确控制网格项目的位置和大小,甚至可以跨越多个行或列。

1. 优化HTML结构

为了更好地利用CSS Grid的特性,我们可以简化HTML结构,将所有直接参与网格布局的元素作为网格容器的直属子元素。这样,CSS Grid可以直接控制它们在网格中的位置。

GPTPLUS
GPTPLUS

GPTPLUS, 由GPT-4和GPT-3.5支持,为您的写作、翻译、代码分析和问答需求提供最准确、有效的AI反馈。

下载

优化后的HTML代码:

<button class="node date-grid">
  <time class='gray'>3</time>
  <div class="next"></div>
  <div class="last"></div>
</button>

在这个结构中,我们将date-grid作为网格容器,time、next和last作为其直接的网格项。time元素被赋予了gray类,以便在CSS中更容易地引用和样式化。

2. 实现CSS Grid布局

接下来,我们将使用CSS Grid属性来定义和分配网格区域。

CSS代码:

.date-grid {
  height: 100px; /* 定义容器高度 */
  display: grid; /* 将元素设置为网格容器 */
  grid-template-columns: 120px 25px; /* 定义两列:左侧120px,右侧25px */
  grid-template-rows: 1fr 1fr; /* 定义两行:各占1份可用空间 */
  grid-template-areas: "gray next" /* 定义网格区域:第一行,左侧为gray,右侧为next */
                       "gray last"; /* 定义网格区域:第二行,左侧为gray,右侧为last */
  padding: 0; /* 移除内边距 */
  border-style: none; /* 移除边框样式 */
}

.gray {
  grid-area: gray; /* 将此元素放置在名为"gray"的网格区域 */
  display: grid; /* 使其内部内容也能使用网格布局 */
  place-content: center; /* 在其自身区域内水平垂直居中内容 */
  background: #e9ecef; /* 背景颜色 */
}

time {
  font-size: 24px; /* 字体大小 */
}

.next {
  grid-area: next; /* 将此元素放置在名为"next"的网格区域 */
  background: #0060df; /* 背景颜色 */
}

.last {
  grid-area: last; /* 将此元素放置在名为"last"的网格区域 */
  background: #d53343; /* 背景颜色 */
}

关键CSS Grid属性解析:

  • display: grid;: 这是启用CSS Grid布局的基础。将.date-grid声明为一个网格容器。
  • grid-template-columns: 120px 25px;: 定义了网格的列结构。这里创建了两列:第一列宽度固定为120px,用于放置主内容;第二列宽度固定为25px,用于放置两个小方块。
  • grid-template-rows: 1fr 1fr;: 定义了网格的行结构。这里创建了两行,每行都占据可用空间的一等份(1fr),这意味着它们将等高。
  • grid-template-areas: "gray next" "gray last";: 这是实现复杂布局的关键。它通过命名区域来定义网格的布局模式:
    • "gray next": 表示网格的第一行。第一列是gray区域,第二列是next区域。
    • "gray last": 表示网格的第二行。第一列仍然是gray区域,第二列是last区域。
    • 通过这种方式,gray区域自动跨越了两行,而next和last区域则分别占据了右侧的第一行和第二行。
  • grid-area: gray; / grid-area: next; / grid-area: last;: 这些属性将HTML元素分配到之前grid-template-areas中定义的命名区域。
  • place-content: center;: 这是align-content和justify-content的简写形式。在.gray元素中,它用于将其内部内容(即time元素中的数字“3”)在水平和垂直方向上居中显示。

优势与注意事项

优势:

  1. 语义化布局: grid-template-areas允许我们通过直观的名称来定义布局,使得CSS代码更易读、易懂。
  2. 结构清晰: 相较于多层嵌套的Flexbox,CSS Grid能够以更扁平的HTML结构实现复杂的二维布局。
  3. 响应式设计友好: 通过媒体查询,可以轻松调整grid-template-columns、grid-template-rows和grid-template-areas的值,以适应不同屏幕尺寸。
  4. 精确控制: Grid提供了对行、列及其间距的精细控制,使得布局更加精确。

注意事项:

  1. 浏览器兼容性: 虽然现代浏览器对CSS Grid的支持已经非常完善,但在开发时仍需考虑目标用户的浏览器版本,并进行必要的测试。对于非常老的浏览器,可能需要提供降级方案。
  2. 学习曲线: 对于初学者而言,CSS Grid的概念(如网格线、网格区域、隐式网格等)可能需要一定时间来理解和掌握。建议通过实践和查阅官方文档来加深理解。
  3. 避免滥用: CSS Grid非常强大,但并非所有布局都必须使用它。对于简单的单向布局(如一行或一列),Flexbox可能更为简洁高效。选择最适合当前布局需求的工具是关键。

总结

通过本教程,我们学习了如何利用CSS Grid将一个复杂的“大方块左侧,小方块右侧垂直堆叠”的布局需求从概念变为现实。核心在于理解display: grid、grid-template-columns、grid-template-rows和grid-template-areas等属性的协同作用。CSS Grid为前端开发者提供了前所未有的布局能力,使我们能够创建更加灵活、健壮和语义化的网页界面。掌握CSS Grid,将极大地提升您在网页布局方面的效率和创造力。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

434

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

600

2023.08.10

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

2

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

58

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

30

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

59

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

25

2026.03.03

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

79

2026.02.28

Golang 工程化架构设计:可维护与可演进系统构建
Golang 工程化架构设计:可维护与可演进系统构建

Go语言工程化架构设计专注于构建高可维护性、可演进的企业级系统。本专题深入探讨Go项目的目录结构设计、模块划分、依赖管理等核心架构原则,涵盖微服务架构、领域驱动设计(DDD)在Go中的实践应用。通过实战案例解析接口抽象、错误处理、配置管理、日志监控等关键工程化技术,帮助开发者掌握构建稳定、可扩展Go应用的最佳实践方法。

61

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

CSS教程
CSS教程

共754课时 | 39.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号