当前位置: 首页 > article >正文

【JavaWeb学习 | 第六篇】CSS(万字长文警告)

【Java Web学习 | 第六篇】CSS万字长文警告 - 现代布局核心Flexbox Grid 响应式设计2026最新版这是 CSS 系列的高潮篇前面我们已经掌握了基础语法、元素显示模式、背景和盒子模型。现在终于来到现代布局部分——Flexbox弹性布局和CSS Grid网格布局。作为 Java Web 后端开发者学好这部分后你就能独立搭建美观、响应式的后台管理页面、登录页、仪表盘等无需依赖大量第三方 CSS 框架也能快速与 Spring Boot 项目前端联调。本篇特点内容较多万字级别但采用“快学快用”结构——核心概念 属性速查 完整示例 最佳实践 小练习 对比总结。建议分 2-3 次阅读边看边在 VS Code 中敲代码用 Live Server 实时预览。1. 为什么需要现代布局回顾历史传统布局float position table痛点很多垂直居中困难等高列难以实现响应式适配麻烦代码复杂、维护性差2026 年主流方案Flexbox一维布局神器水平或垂直方向——适合导航、卡片列表、按钮组等。CSS Grid二维布局神器同时控制行和列——适合整体页面布局、仪表盘、复杂网格。两者结合Grid 做大框架Flexbox 做内部微调最佳实践。核心记忆Flexbox 管“一根轴”Grid 管“整个网格”。2. Flexbox 弹性布局最常用一维布局核心概念Flex 容器父元素display: flex或display: inline-flexFlex 项目子元素自动成为 flex item两根轴主轴main axis默认水平由flex-direction控制交叉轴cross axis与主轴垂直容器属性作用于父元素——速查表.container{display:flex;/* 开启 Flexbox */flex-direction:row;/* 主轴方向row | row-reverse | column | column-reverse */flex-wrap:nowrap;/* 换行nowrap | wrap | wrap-reverse */justify-content:center;/* 主轴对齐flex-start | center | flex-end | space-between | space-around | space-evenly */align-items:center;/* 交叉轴对齐单行stretch | center | flex-start | flex-end | baseline */align-content:stretch;/* 交叉轴对齐多行 */gap:16px;/* 间隙推荐替代 margin */}项目属性作用于子元素.item{flex:1 1 auto;/* 简写grow shrink basis最重要 *//* flex-grow: 1; *//* 放大比例 *//* flex-shrink: 1; *//* 缩小比例 *//* flex-basis: 0%; *//* 初始大小 */order:2;/* 排序数值越小越靠前 */align-self:center;/* 单独控制交叉轴对齐 */}完整 Flexbox 示例导航 卡片列表!DOCTYPEhtmlhtmllangzh-CNheadmetacharsetUTF-8metanameviewportcontentwidthdevice-width, initial-scale1.0titleFlexbox 实战示例/titlestyle*{box-sizing:border-box;margin:0;padding:0;}body{font-family:Microsoft YaHei,sans-serif;padding:20px;background:#f8f9fa;}/* 导航栏 */.nav{display:flex;justify-content:space-between;align-items:center;background:#007bff;color:white;padding:16px 24px;border-radius:8px;margin-bottom:30px;}.nav-links{display:flex;gap:24px;}.nav-links a{color:white;text-decoration:none;}/* 卡片容器 */.cards{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;}.card{flex:1 1 300px;/* 关键弹性伸缩最小 300px */max-width:350px;background:white;border-radius:12px;padding:24px;box-shadow:0 10px 30pxrgba(0,0,0,0.1);display:flex;flex-direction:column;}.card h3{margin-bottom:12px;}.card p{flex-grow:1;}/* 让内容占满按钮靠底 */.card button{margin-top:auto;/* 按钮自动推到底部 */}/style/headbodynavclassnavdivclasslogoJava Web 系统/divdivclassnav-linksahref#首页/aahref#用户管理/aahref#API 文档/aahref#关于/a/div/navdivclasscardsdivclasscardh3用户管理/h3pCRUD 操作示例结合 Spring Boot JPA/pbutton进入/button/divdivclasscardh3数据统计/h3p仪表盘页面使用 Chart.js/pbutton进入/button/divdivclasscardh3系统设置/h3p配置中心与安全管理/pbutton进入/button/div/div/body/htmlFlexbox 经典场景水平/垂直居中justify-content: center; align-items: center;等分布局flex: 1;圣杯/双飞翼布局结合 wrap响应式导航小屏自动换行3. CSS Grid 网格布局二维布局神器核心概念Grid 容器display: grid轨道Track行rows和列columns网格线Grid Lines定义轨道边界网格区域Grid Areas命名区域简化布局容器属性速查.grid-container{display:grid;grid-template-columns:1fr 2fr 1fr;/* 列轨道fr 是分数单位推荐 */grid-template-rows:100px auto 120px;/* 行轨道 */gap:20px;/* 行间隙 列间隙 */grid-template-areas:/* 命名区域超级实用 */header header headersidebar main mainfooter footer footer;justify-content:center;/* 整个网格对齐 */align-items:start;}项目属性.item{grid-column:1 / 3;/* 跨越列起始线 / 结束线 */grid-row:span 2;/* 跨越行span 关键字 */grid-area:header;/* 使用命名区域 */}完整 Grid 示例后台仪表盘布局divclassdashboardstyledisplay:grid;grid-template-columns:250px 1fr 300px;grid-template-rows:80px 1fr 80px;gap:20px;height:100vh;padding:20px;!-- 头部 --headerstylegrid-column:1 / -1;background:#007bff;color:white;display:flex;align-items:center;padding:0 24px;管理系统/header!-- 侧边栏 --asidestylebackground:white;padding:20px;菜单列表/aside!-- 主内容 --mainstylebackground:white;padding:20px;主要数据区域可嵌套 Flexbox/main!-- 右侧面板 --divstylebackground:white;padding:20px;统计卡片/div!-- 页脚 --footerstylegrid-column:1 / -1;background:#f8f9fa;padding:16px;text-align:center;© 2026 Java Web/footer/divGrid 经典场景整体页面框架header/sidebar/main/footer图片瀑布流 / 产品网格响应式仪表盘12 列系统repeat(12, 1fr)4. Flexbox vs Grid 对比2026 选择指南场景推荐方案理由导航栏、按钮组Flexbox一维方向简单对齐卡片列表、等高元素Flexbox弹性伸缩容易整体页面布局Grid二维精确控制复杂仪表盘Grid FlexGrid 框架 Flex 内部微调响应式小组件Flexbox更轻量最佳实践Grid 做大结构Flexbox 做细节。5. 响应式设计Media Queries Container Queries基础媒体查询/* 移动端优先 */.container{display:flex;flex-direction:column;}/* 平板及以上 */media(min-width:768px){.container{flex-direction:row;}}/* 桌面大屏 */media(min-width:1024px){.cards{grid-template-columns:repeat(4,1fr);}}2026 新特性Container Queries容器查询基于父容器尺寸而非视口更适合组件化开发。.card-container{container-type:inline-size;/* 定义容器 */}container(min-width:400px){.card{flex-direction:row;}}6. 小练习立即动手巩固掌握用 Flexbox 改造上一篇文章的卡片列表实现等高 按钮靠底效果。用 Grid 搭建一个三栏布局侧边 主内容 右侧面板。结合媒体查询实现导航在小屏自动变成竖向菜单。创建一个登录页Grid 整体布局 Flexbox 居中表单卡片。下一篇文章预告《【Java Web学习 | 第七篇】前端 - JavaScript 基础与 DOM 操作》我们将进入 JavaScript 部分学习变量、函数、事件、DOM 操作为前后端交互AJAX/Fetch 调用 Spring Boot API打基础。万字长文结束这篇内容较多但每部分都有可直接复制的完整示例。建议先把 Flexbox 示例跑起来再尝试 Grid。有任何问题随时问想要圣杯布局 / 完整仪表盘示例代码需要Flexbox Grid 结合的后台模板或直接进入JavaScript篇回复“给我仪表盘示例”或“下一篇 JS”我立刻继续坚持下来你的 CSS 布局能力已经达到企业可用水平。Java Web 全栈之路第六步稳稳拿下

相关文章:

【JavaWeb学习 | 第六篇】CSS(万字长文警告)

【Java Web学习 | 第六篇】CSS(万字长文警告) - 现代布局核心:Flexbox Grid 响应式设计(2026最新版) 这是 CSS 系列的高潮篇!前面我们已经掌握了基础语法、元素显示模式、背景和盒子模型。现在终于来到现…...

Boss-Key终极指南:3分钟掌握Windows隐私保护神器

Boss-Key终极指南:3分钟掌握Windows隐私保护神器 【免费下载链接】Boss-Key 老板来了?快用Boss-Key老板键一键隐藏静音当前窗口!上班摸鱼必备神器 项目地址: https://gitcode.com/gh_mirrors/bo/Boss-Key 在数字化办公时代&#xff0c…...

QT:Tab Widget的进阶应用与实战技巧

1. Tab Widget的动态管理技巧 第一次用QT做带标签页的界面时,我习惯在设计器里把Tab页都固定好。直到接手一个需要动态加载配置文件的仪表盘项目,才发现动态增删Tab才是真实开发中的常态。比如用户点击"新建图表"按钮时,我们需要实…...

别再傻傻分不清了!MOC3081、3061、3041、3021这几款可控硅光耦到底怎么选?

MOC30xx系列可控硅光耦深度选型指南:从参数解析到实战避坑 在电力电子设计领域,可控硅光耦就像电路中的"安全卫士",既要确保强弱电之间的可靠隔离,又要精准触发功率器件。MOC30xx系列作为经典的可控硅驱动光耦&#xff…...

Labview 机器视觉(4)之 图像处理进阶 - 像素操作与批量保存

1. 像素操作:从入门到精通的实战指南 在工业自动化领域,图像处理的核心往往在于对像素级别的精准控制。LabVIEW作为一款强大的图形化编程工具,提供了丰富的像素操作函数,让工程师能够像搭积木一样构建复杂的视觉处理流程。 我第一…...

Arrow终极指南:5步掌握可视化游戏叙事设计工具

Arrow终极指南:5步掌握可视化游戏叙事设计工具 【免费下载链接】Arrow Game Narrative Design Tool 项目地址: https://gitcode.com/gh_mirrors/arrow/Arrow Arrow是一款免费开源的游戏叙事设计工具,专门用于创建互动非线性故事和文本冒险游戏。这…...

TIA Portal精智面板动画外观实战:从基础图形到变量控制

1. 精智面板动画外观入门指南 第一次接触TIA Portal的精智面板动画功能时,我被它强大的可视化能力惊艳到了。简单拖拽几个图形,关联PLC变量,就能实现酷炫的工业界面效果。下面我就用最直白的语言,带大家从零开始玩转这个功能。 首…...

高效构建智能媒体库:MetaTube插件全方位应用指南

高效构建智能媒体库:MetaTube插件全方位应用指南 【免费下载链接】jellyfin-plugin-metatube MetaTube Plugin for Jellyfin/Emby 项目地址: https://gitcode.com/gh_mirrors/je/jellyfin-plugin-metatube MetaTube是一款专为Jellyfin和Emby设计的开源元数据…...

【昇腾】Deepseek双机:高效网络配置与故障排查指南

1. 昇腾AI双机组网基础架构 第一次接触昇腾AI服务器双机部署时,最让我头疼的就是网络架构设计。不同于普通服务器的千兆网卡互联,昇腾NPU的200G/400G高速网络接口需要特殊的组网方案。这里我结合自己踩过的坑,给大家拆解两种最常见的组网模式…...

树莓派无头模式终极指南:不接显示器,用SSH+VNC搞定所有开发调试

树莓派无头模式终极指南:不接显示器,用SSHVNC搞定所有开发调试 当你把树莓派塞进机器人底盘、挂在墙上作为智能家居中枢,或是藏在机柜里充当服务器时,最不想看到的就是拖着一堆显示器和线材。作为嵌入式开发老手,我经历…...

联邦学习安全指南:5种对抗攻击防御策略实测(PySyft案例详解)

联邦学习安全实战:5类对抗攻击防御策略与PySyft代码实现 联邦学习作为分布式机器学习的前沿技术,在医疗、金融等隐私敏感领域展现出巨大潜力。然而,其去中心化的特性也带来了独特的安全挑战——恶意参与者可能通过精心设计的对抗样本破坏全局…...

基于Qt框架的PC端学生信息管理系统设计与实现

1. 为什么选择Qt开发学生信息管理系统? 第一次接触学生信息管理系统开发时,我尝试过用Java Swing、Python Tkinter等多种GUI框架,最后发现Qt才是真正的"生产力工具"。Qt的信号槽机制让界面交互变得异常简单,跨平台特性又…...

自动驾驶避障算法实战:从动态规划(DP)到模型预测控制(MPC)的Matlab代码详解

自动驾驶避障算法实战:从动态规划到模型预测控制的Matlab实现 自动驾驶技术的核心挑战之一是如何在复杂环境中实现安全避障。本文将深入探讨两种主流算法——动态规划(DP)与模型预测控制(MPC)的代码级实现,通过Matlab示例展示它们如何协同工作来解决这一…...

别再让扰动拖慢你的系统!手把手教你用MATLAB/Simulink实现非线性扰动观测器(附完整代码)

非线性扰动观测器实战指南:从理论到MATLAB/Simulink完整实现 在控制工程领域,非线性扰动观测器(NDOB)就像一位隐形的守护者,默默抵消着系统运行中各种未知干扰的影响。想象一下,当你精心设计的控制器因为突…...

罗技鼠标宏压枪脚本:绝地求生精准射击的终极解决方案

罗技鼠标宏压枪脚本:绝地求生精准射击的终极解决方案 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 还在为《绝地求生》中的后坐力控…...

气象防灾实战:如何用QGIS快速生成暴雨等值面预警图?(含历史数据对比)

气象防灾实战:如何用QGIS快速生成暴雨等值面预警图?(含历史数据对比) 暴雨灾害的预警与防控一直是应急管理和市政规划领域的核心挑战。传统的气象数据分析往往依赖专业软件和复杂代码,让非技术背景的从业者望而却步。本…...

从原理到实战:AEC如何成为现代通信的“静音守护者”

1. 回声:从自然现象到通信难题 想象一下,你正在和远方的朋友视频通话,突然听到自己的声音像山谷回音一样不断重复。这种恼人的现象就是我们常说的"声学回声"。在自然界中,回声是声音遇到障碍物反射形成的物理现象&#…...

Legacy iOS Kit终极指南:轻松完成旧款iOS设备降级与恢复

Legacy iOS Kit终极指南:轻松完成旧款iOS设备降级与恢复 【免费下载链接】Legacy-iOS-Kit An all-in-one tool to downgrade/restore, save SHSH blobs, and jailbreak legacy iOS devices 项目地址: https://gitcode.com/gh_mirrors/le/Legacy-iOS-Kit Lega…...

UniAD高版本环境实战:CUDA11.6+PyTorch1.12避坑全记录(附完整依赖清单)

UniAD高版本环境实战:CUDA11.6PyTorch1.12避坑全记录(附完整依赖清单) 当计算机视觉工程师尝试复现前沿论文时,环境配置往往成为第一道门槛。UniAD作为自动驾驶领域的统一大模型,其官方文档推荐的环境配置(…...

ComfyUI-AdvancedLivePortrait插件实战:5分钟搞定静态人像表情动画(附模型下载)

ComfyUI-AdvancedLivePortrait插件实战:静态人像动态化的高效解决方案 想象一下,你手头有一张精美的静态人像照片,却需要在短时间内为它注入生命力——让眼睛自然眨动、嘴角微微上扬,甚至实现头部转动的流畅动画。传统方法可能需要…...

Kubernetes与Helm包管理最佳实践

Kubernetes与Helm包管理最佳实践 1. Helm核心概念 1.1 什么是Helm Helm是Kubernetes的包管理工具,用于简化应用的部署和管理。它允许开发者和运维人员定义、安装和升级Kubernetes应用。 1.2 Helm架构组件 Helm客户端:命令行工具,用于本地开发…...

你不知道的微信小程序环境判断技巧:wx.getAccountInfoSync()与__wxConfig深度对比

微信小程序环境判断进阶指南:从API到底层变量的深度解析 在微信小程序开发中,环境判断是一个看似简单却暗藏玄机的基础功能。许多开发者可能满足于简单的if-else判断,却忽略了不同判断方式对性能、稳定性和可维护性的深远影响。本文将带你深入…...

从零开始玩转Arduino:手把手教你用MOS管和继电器控制大电流设备(附电路图)

从零开始玩转Arduino:手把手教你用MOS管和继电器控制大电流设备(附电路图) 当你第一次尝试用Arduino控制大功率设备时,可能会遇到一个常见问题:小小的开发板输出引脚根本无法直接驱动电机、灯带或加热管。这时候&#…...

手把手教你用CH32V208开发板实现蓝牙BLE5.3通信(附完整工程源码)

基于CH32V208开发板的蓝牙BLE5.3实战开发指南 在物联网设备爆发式增长的今天,低功耗蓝牙(BLE)技术因其低功耗、低成本的优势,成为短距离无线通信的首选方案之一。作为一款集成了BLE5.3模块的RISC-V微控制器,CH32V208为…...

【机器人导航】Ubuntu16.04下北斗星通接收机硬件连接与串口配置指南

1. 北斗星通接收机硬件连接指南 第一次接触北斗星通接收机时,我完全被它铝合金外壳的专业感震撼到了。这种工业级设备虽然看起来复杂,但只要掌握正确方法,连接起来其实比想象中简单得多。我们以NC502-D型接收机为例,这是机器人导航…...

GHelper深度解析:重新定义华硕笔记本性能控制体验

GHelper深度解析:重新定义华硕笔记本性能控制体验 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models 项目地址: h…...

HarmonyOS 实时公交服务开发实战:从零搭建到功能优化

1. 实时公交服务的核心价值与HarmonyOS适配性 站在公交站台掏出手机查看车辆到站时间,这种场景已经成为现代城市生活的常态。实时公交服务之所以成为出行类应用的标配功能,关键在于它解决了用户三大痛点:无效等待焦虑、时间规划困难和路线选择…...

统计了1000+计算机研究生的就业去向后,才知道就业差距这么大!

统计了1000计算机研究生的就业去向后,才知道就业差距这么大! ✦ 今天图图汇总整理了5所不同层次院校公布的计算机学院就业情况,信息包括但不限于就业率、就业单位、就业地域、毕业薪酬等,各位计算机考研人可以参考,在…...

从HC-SR04到智能报警:手把手教你用51单片机做个超声波倒车雷达原型

从HC-SR04到智能报警:手把手教你用51单片机做个超声波倒车雷达原型 在汽车电子和智能硬件领域,倒车雷达作为基础安全配置已经普及多年。但对于电子爱好者和嵌入式开发者来说,用最基础的51单片机搭配HC-SR04超声波模块实现一个具备三级报警功能…...

DiffBIR实战:用Stable Diffusion 2.1修复模糊老照片(附完整配置流程)

DiffBIR实战:用Stable Diffusion 2.1修复模糊老照片(附完整配置流程) 翻开泛黄的相册,那些承载着珍贵记忆的老照片往往因年代久远而变得模糊、褪色甚至破损。传统修复方法需要专业设计师耗费数小时手动修复,而如今&…...