0

0

使用CSS Grid实现灵活的水平布局:方块内嵌方块结构重构指南

DDD

DDD

发布时间:2025-11-27 13:47:16

|

740人浏览过

|

来源于php中文网

原创

使用CSS Grid实现灵活的水平布局:方块内嵌方块结构重构指南

本教程详细演示了如何利用css grid将一个原有的、基于flexbox的垂直“方块内嵌方块”结构转换为水平布局。通过介绍`grid-template-columns`、`grid-template-rows`和`grid-template-areas`等核心grid属性,文章提供了一种高效且语义化的解决方案,以实现主内容区位于左侧,两个小区域垂直堆叠在右侧的复杂二维布局。

1. 布局挑战:从垂直到水平的结构转换

网页设计中,我们经常需要构建包含复杂嵌套元素的布局。一个常见的场景是,一个主内容区域旁边伴随着多个辅助区域。本教程将以一个具体的“方块内嵌方块”结构为例,演示如何将其从最初的垂直排列方式,转换为一种主内容区在左,两个小辅助区域垂直堆叠在右的水平布局。

原始结构描述: 一个名为 .date-grid 的容器包含一个 .node 按钮。这个按钮内部有一个 time 元素(作为主内容区)和一个 .smallHolder 容器。.smallHolder 容器又包含两个小的 div 元素(.next 和 .last),它们水平并排排列。整个 .date-grid 采用 flex-direction: column,使得 time 元素在上方,.smallHolder 在下方。

原始HTML结构:

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

原始CSS样式(关键部分):

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

.date-grid {
    width: 120px;
    height: 100px;
    display: flex;
    flex-direction: column; /* 垂直排列 */
}

.node {
    width: 100%;
    height: 100%;
    background: #e9ecef;
    border: none;
    padding: 0;
}

time {
    display: block;
    height: 75%; /* 占据上方大部分空间 */
    font-size: 24px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.smallHolder {
    width: 100%;
    height: 25%; /* 占据下方剩余空间 */
    display: flex; /* 内部小方块水平排列 */
}

.smallHolder > div {
    width: 25%;
    height: 100%;
    flex-shrink: 0;
    flex-grow: 1;
}

.next { background: #0060df; }  

.last { background: #d53343; } 

这种基于Flexbox的实现对于一维(行或列)布局非常有效。然而,当我们需要同时控制行和列,并进行更复杂的二维布局时,Flexbox的嵌套和调整可能会变得复杂。

2. 引入CSS Grid:二维布局的利器

为了实现主内容区在左侧,两个小辅助区域垂直堆叠在右侧的水平布局,CSS Grid是更优的选择。CSS Grid专为二维布局设计,能够同时管理行和列,并提供强大的区域命名功能,使布局结构清晰易懂。

2.1 重新设计HTML结构

Fotor
Fotor

Fotor 在线照片编辑器

下载

首先,我们可以简化HTML结构,将所有直接参与Grid布局的元素作为 .date-grid 的直接子元素,或者通过类名进行标识。在这里,我们将 time、.next 和 .last 直接作为 button.node.date-grid 的子元素。

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

请注意,我们将 time 元素添加了 gray 类,以便在CSS Grid中对其进行样式和定位。

2.2 CSS Grid布局实现

接下来,我们将使用CSS Grid属性来定义新的布局:

.date-grid {
  height: 100px; /* 容器高度保持不变 */
  display: grid; /* 启用CSS Grid布局 */
  /* 定义列:第一列120px,第二列25px */
  grid-template-columns: 120px 25px; 
  /* 定义行:两行等高 */
  grid-template-rows: 1fr 1fr; 
  /* 定义网格区域,实现语义化布局 */
  grid-template-areas: 
    "gray next" 
    "gray last";
  padding: 0;
  border-style: none;
}

.gray {
  grid-area: gray; /* 将此元素放置在名为 'gray' 的区域 */
  display: grid; /* 内部使用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;: 将容器设置为一个网格容器,其直接子元素将成为网格项。
  • grid-template-columns: 120px 25px;: 定义了两列。第一列的宽度固定为 120px,用于主内容区;第二列的宽度固定为 25px,用于两个小辅助区域。
  • grid-template-rows: 1fr 1fr;: 定义了两行。1fr 表示“一个分数单位”,这意味着这两行将等分容器的可用高度。这样,.next 和 .last 可以各占据一半的高度。
  • grid-template-areas: "gray next" "gray last";: 这是Grid布局中非常强大且直观的特性。它允许我们通过命名来定义网格区域,并直观地“绘制”出布局结构。
    • "gray next" 表示第一行:第一列是 gray 区域,第二列是 next 区域。
    • "gray last" 表示第二行:第一列是 gray 区域,第二列是 last 区域。
    • 从这个定义可以看出,gray 区域横跨了两行,占据了第一列的全部空间。next 区域占据了第二列的第一行,last 区域占据了第二列的第二行。
  • grid-area: gray; / grid-area: next; / grid-area: last;: 将相应的HTML元素分配到之前定义的具名网格区域中。
  • place-content: center;: 这是一个简写属性,等同于 align-content: center; 和 justify-content: center;。在这里,它用于将 time 元素(作为 gray 区域的内容)在其网格单元内部水平和垂直居中

3. 注意事项与总结

  • Flexbox与Grid的选择: Flexbox主要用于一维布局(行或列),适合组件内部的排列。CSS Grid则专为二维布局设计,能够同时控制行和列,更适合页面整体布局或复杂组件的结构。在需要同时管理行和列的场景下,Grid通常能提供更简洁、更强大的解决方案。
  • 语义化布局: grid-template-areas 提供了一种高度语义化的方式来定义布局,使得CSS代码更易读、更易维护。通过区域命名,我们可以一目了然地看出每个元素在布局中的位置和作用。
  • 结构简化: 采用CSS Grid后,我们能够简化HTML结构。原有的 .smallHolder 容器不再需要,因为Grid可以直接管理其子元素的二维位置。
  • 响应式设计 CSS Grid与媒体查询结合,可以非常方便地实现复杂的响应式布局。通过改变 grid-template-columns、grid-template-rows 和 grid-template-areas 的值,可以轻松调整不同屏幕尺寸下的布局。
  • 浏览器兼容性: 现代浏览器对CSS Grid的支持已经非常完善。在需要支持旧版浏览器的项目中,可能需要考虑Polyfill或备用方案。

通过本教程,我们学习了如何利用CSS Grid的强大功能,将一个复杂的垂直内嵌结构优雅地转换为水平布局。这种方法不仅代码更简洁,而且为未来的布局调整和响应式设计提供了更大的灵活性。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

448

2023.07.18

堆和栈区别
堆和栈区别

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

606

2023.08.10

flex教程
flex教程

php中文网为大家带来了flex教程合集,Flex是采用Flex布局的元素,称为Flex容器(flex container),简称"容器",它的所有子元素自动成为容器成员,有三个核心概念: flex项,需要布局的元素;flex容器,其包含flex项;排列方向,这决定了flex项的布局方向。php中文网还为大家带来flex的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

372

2023.06.14

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

76

2026.03.13

Python异步编程与Asyncio高并发应用实践
Python异步编程与Asyncio高并发应用实践

本专题围绕 Python 异步编程模型展开,深入讲解 Asyncio 框架的核心原理与应用实践。内容包括事件循环机制、协程任务调度、异步 IO 处理以及并发任务管理策略。通过构建高并发网络请求与异步数据处理案例,帮助开发者掌握 Python 在高并发场景中的高效开发方法,并提升系统资源利用率与整体运行性能。

116

2026.03.12

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

345

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

62

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

109

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

108

2026.03.06

热门下载

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

精品课程

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

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.6万人学习

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

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