新闻中心
使用Flexbox和CSS实现响应式圆形与方形布局

本文将详细介绍如何利用HTML和CSS的Flexbox布局,创建包含圆形或方形元素及配套文本的灵活布局。教程涵盖了Flexbox的核心属性,如display: flex、justify-content和align-items,以实现水平排列。同时,还将讲解如何通过媒体查询(Media Queries)实现响应式设计,使布局在不同屏幕尺寸下自动调整为垂直堆叠,确保用户体验。
1. 引言:Flexbox布局的优势
在现代网页开发中,Flexbox(弹性盒子)模块提供了一种高效的方式来布局、对齐和分配容器中项目空间。它使得复杂布局的实现变得简单,尤其适用于创建一维布局(行或列)。本教程将利用Flexbox的强大功能,构建一个包含圆形或方形图形及其描述文本的布局,并确保其在不同设备上的响应性。
2. HTML结构搭建
首先,我们需要定义清晰的HTML结构。我们将使用一个主容器来包裹一行中的所有元素组,每个元素组又包含一个图形(可以是div或img)和一个段落文本。
<div class="row">
<!-- 第一个元素组 -->
<div class="circle-wrapper">
<div class="circle">
@@##@@
</div>
<p>这是一段关于船只的描述文本。</p>
</div>
<!-- 第二个元素组 -->
<div class="circle-wrapper">
<div class="circle">
@@##@@
</div>
<p>这是一段关于猫咪的描述文本。</p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/xiazai/code/10249">
<img src="https://img.php.cn/upload/webcode/000/000/016/176121720667533.jpg" alt="cqcms通用企业建站(PC+wap)2.9">
</a>
<div class="aritcle_card_info">
<a href="/xiazai/code/10249">cqcms通用企业建站(PC+wap)2.9</a>
<p>cqcms通用企业建站介绍 苍穹企业网站管理系统(CQCMS)软件是国产PHP网站内容管理系统:CQcms内容管理系统 ,它将成为您轻松建站的利器。模板全部使用文件形式保存,对用户设计模板、网站升级转移均提供很大的便利,健壮的模板标签为站长DIY自己的网站提供了强有力的支持。MVC框架,自定义标签,模板文件修改非常方便,PC+WAP响应式布局,一个域名,自动识别终端,一个后台同时管理PC和wap。</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="cqcms通用企业建站(PC+wap)2.9">
<span>0</span>
</div>
</div>
<a href="/xiazai/code/10249" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="cqcms通用企业建站(PC+wap)2.9">
</a>
</div>
</div>
</div>
<div class="row">
<!-- 纯色圆形示例 -->
<div class="circle-wrapper">
<div class="circle"></div>
<p>这是一段纯色圆形的描述文本。</p>
</div>
<!-- 另一个纯色圆形示例 -->
<div class="circle-wrapper">
<div class="circle"></div>
<p>这是一段纯色圆形的描述文本。</p>
</div>
</div>- .row:作为Flex容器,负责横向排列其子元素(.circle-wrapper)。
- .circle-wrapper:每个独立的元素组,内部包含一个图形和一段文本。它自身也是一个Flex容器,但其子元素是垂直排列的。
- .circle:代表圆形或方形的图形区域,可以是一个div或包含img标签的div。
- p:图形下方的描述文本。
3. CSS样式实现:Flexbox核心属性
接下来,我们将应用CSS样式来布局这些元素,并使用Flexbox属性进行精确控制。
/* 基础样式 */
body {
font-family: Arial, sans-serif;
margin: 20px;
background-color: #f4f4f4;
}
/* 1. 容器 (.row) 的 Flexbox 设置 */
.row {
display: flex; /* 激活Flexbox布局 */
justify-content: space-around; /* 子项目在主轴(水平)上均匀分布,两端留有空间 */
margin-bottom: 60px; /* 行之间的垂直间距 */
flex-wrap: wrap; /* 允许项目在空间不足时自动换行 */
gap: 20px; /* 项目之间的间距(现代Flexbox属性) */
}
/* 2. 单个项目包裹器 (.circle-wrapper) 的 Flexbox 设置 */
.circle-wrapper {
display: flex; /* 激活Flexbox布局 */
flex-direction: column; /* 内部元素(图形和文本)垂直堆叠 */
align-items: center; /* 内部元素在交叉轴(水平)居中对齐 */
text-align: center; /* 确保文本居中 */
background-color: white;
padding: 15px;
border-radius: 8px;
box-shadow: 0 2px 5px rgba(0,0,0,0.1);
flex-shrink: 0; /* 防止项目在空间不足时过度缩小 */
min-width: 200px; /* 设置最小宽度,避免内容过窄 */
}
/* 3. 图形 (.circle) 的样式 */
.circle {
width: 100px;
height: 100px;
background: #ff6347; /* 默认纯色背景 */
border-radius: 50%; /* 制作圆形 */
display: block; /* 确保元素占据独立空间,消除图片底部空白 */
margin-bottom: 15px; /* 与下方文本的间距 */
overflow: hidden; /* 隐藏超出圆形区域的内容,尤其用于图片 */
}
/* 如果 .circle 内部包含图片 */
.circle img {
width: 100%;
height: 100%;
object-fit: cover; /* 确保图片填充整个圆形区域,并裁剪多余部分 */
border-radius: 50%; /* 确保图片自身也是圆形 */
}
/* 4. 文本 (p) 的样式 */
.circle-wrapper p {
padding: 10px 15px;
background: #e0e0e0;
border-radius: 5px;
color: #333;
font-size: 14px;
line-height: 1.5;
margin: 0; /* 移除p标签默认外边距 */
}- .row: 设定为display: flex使其子元素水平排列。justify-content: space-around确保了子元素在主轴上的均匀分布,并在两端留有空白。flex-wrap: wrap是实现响应性的关键,当空间不足时,项目会自动换行。
- .circle-wrapper: 同样设定为display: flex,但flex-direction: column使其内部的图形和文本垂直堆叠。align-items: center则将这些垂直堆叠的元素在交叉轴(即水平方向)上居中。
-
.circle: 通过设置width、height和border-rad
ius: 50%来创建圆形。如果需要方形,则移除border-radius或设置为0。overflow: hidden和object-fit: cover对于内部包含图片的圆形尤其重要,它们确保图片完美填充圆形区域。
4. 实现响应式设计:媒体查询
为了让布局在不同屏幕尺寸下都能良好展示,我们需要使用媒体查询(Media Queries)。当屏幕宽度小于某个阈值时,我们将改变主容器的flex-direction,使其子元素从水平排列变为垂直堆叠。
/* 媒体查询:针对中等屏幕设备,例如平板电脑 */
@media (max-width: 768px) {
.row {
flex-direction: column; /* 在小屏幕上,主轴变为垂直方向 */
align-items: center; /* 容器内的项目在交叉轴(水平)居中 */
gap: 30px; /* 增加垂直间距 */
}
.circle-wrapper {
width: 80%; /* 让每个项目占据大部分宽度 */
max-width: 300px

以上就是使用Flexbox和CSS实现响应式圆形与方形布局的详细内容,更多请关注其它相关文章!
# html
# 湖北seo软件平台
# 玉树抖音关键词排名
# 新河附近网站建设
# 健身房抖音推广营销
# 云浮网站建设中心
# 网络推广建网站方案设计
# 廉江seo
# 温州爱采购seo
# 香港关键词排名效果乐云seo
# 自己的
# 移除
# 表单
# 两种
# 选择器
# 超链接
# 使其
# 自适应
# 企业建站
# 这是
# overflow
# 排列
# css样式
# 响应式设计
# 平板电脑
# cdn
# 平板
# 电脑
# app
# css
# 加盟账号怎么做营销推广
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
漫蛙网页登录入口 漫蛙漫画官方授权网址
c++ 命名空间怎么用 c++ namespace使用指南
豆包手机助手发布技术预览版:直接嵌入手机系统!努比亚样机发售
如何仅使用CSS更改登录界面背景图像图标的颜色
4399体育竞技小游戏_4399小游戏赛事入口
J*aScript对象创建方式_J*aScript设计模式应用
excel如何生成目录 excel一键生成工作表目录超链接
必由学官方平台入口 必由学在线课堂登录地址
LocoySpider如何部署到云服务器_LocoySpider云部署的远程配置
qq邮箱发邮件给国外发不出去_QQ邮箱国际邮件发送失败原因与解决
谷歌邮箱网页版官方页面入口 谷歌邮箱网页端快速访问
Win11如何开启讲述人功能 Win11屏幕阅读器(讲述人)开启与关闭【教程】
Yandex搜索引擎一键访问入口_俄罗斯Yandex官网免登录
J*a里如何实现订单支付与库存同步功能_支付库存同步项目开发方法说明
京东单号查询入口_京东快递订单追踪入口
在Go开发中优雅管理ListenAndServe进程:GoSublime集成方案
文心一言怎样用批量生成做多版文案_文心一言用批量生成做多版文案【批量创作】
俄罗斯浏览器官网直达链接 俄罗斯浏览器最新在线入口导航
星露谷物语官网入口 星露谷物语游戏官网入口
Python字典中优雅地迭代剩余元素的方法
Win10怎么制作U盘启动盘 Win10系统安装U盘制作教程【详解】
如何将HTML表格多行数据保存到Google Sheets
在React函数组件中利用原生HTML5进行邮箱地址验证
《明末:渊虚之羽》设计师谈设计角色:那会刚毕业 充满激情
解决 MongoDB 聚合查询中对象数组 _id 匹配问题
Golang如何测试channel通信行为_Golang channel通信测试与分析方法
微博网页版首页入口 微博电脑端官网登录链接
探索高级语言到C/C++的转译路径:以Go为例及内存管理策略
php源码怎么在电脑上测试_电脑测试php源码方法步骤【教程】
c++如何使用Catch2编写单元测试_c++简洁易用的BDD风格测试框架
Win10怎么设置静态IP地址 Win10手动配置IP地址步骤【指南】
Google翻译怎么语音输入_Google翻译语音输入功能使用与设置方法
斑马英语APP如何开启夜间护眼阅读_斑马英语APP夜间模式与低蓝光设置教程
如何优雅地扩展SprykerGlue后端API授权逻辑,使用spryker/glue-backend-api-application-authorization-connector-extension
韩小圈电脑版在线入口_网页版免费登录地址
CSS响应式网页如何实现主次模块比例自适应_flex-grow与flex-shrink调整
MinIO大规模对象列表性能瓶颈深度解析与外部元数据管理策略
LINUX怎么设置定时任务_LINUX crontab配置教程
QQ邮箱正确登录入口_QQ邮箱官方网站使用地址
天眼查怎么看公司融资情况 天眼查企业融资历史查询步骤【攻略】
qq音乐在线播放入口_qq音乐电脑版登录链接
抖音商城签到领现金是真的吗_抖音商城签到奖励与提现说明
解决Python单元测试中Mock异常方法调用计数为零的问题
Golang如何实现Web文件静态资源服务器_Golang静态资源服务器开发与实践
b站赚钱渠道_b站收益来源
Win11怎么开启高性能模式_Windows 11电源计划优化设置
Excel中VLOOKUP的第四个参数是干什么用的_Excel VLOOKUP第四参数作用解析
J*aScript中赋值与自增运算符的复杂交互与执行机制
抓大鹅无需下载版 抓大鹅秒玩版入口
Fabric模组开发:自定义物品与物品组的现代管理方法


2025-12-08
浏览次数:次
返回列表
ius: 50%来创建圆形。如果需要方形,则移除border-radius或设置为0。overflow: hidden和object-fit: cover对于内部包含图片的圆形尤其重要,它们确保图片完美填充圆形区域。