
本教程将详细介绍如何使用css flexbox实现一个动态的两列布局,确保每行最多容纳两个子元素,并使其在空间不足时自动换行。特别地,我们将解决当子元素数量为奇数时,如何使最后一行的单个元素水平居中显示的问题,全程无需j*ascript介入。
在网页设计中,我们经常需要创建能够根据内容数量或屏幕尺寸动态调整的布局。本教程的目标是构建一个容器,其内部的子元素按照以下规则排列:
核心挑战在于如何在纯CSS环境下,既实现两列布局与自动换行,又能优雅地处理奇数项的居中问题。Flexbox是解决此类问题的理想工具。
首先,我们需要一个包含多个子元素的父容器。重要的是,子元素应使用类(class)而非ID(id),因为ID在HTML文档中必须是唯一的。
我们将使用一个父div作为Flex容器,内部包含任意数量的子div作为Flex项目。
<div id="container">
<div class="smallerCon">
<div class="smallerLeftBoxText">Lorem ipsum dolor sit, amet consectetur adipisicing elit.</div>
</div>
<div class="smallerCon">
<div class="smallerLeftBoxText">Lorem ipsum dolor sit, amet consectetur adipisicing elit.</div>
</div>
<div class="smallerCon">
<div class="smallerLeftBoxText">Lorem ipsum dolor sit, amet consectetur adipisicing elit.</div>
</div>
<div class="smallerCon">
<div class="smallerLeftBoxText">Lorem ipsum dolor sit, amet consectetur adipisicing elit.</div>
</div>
<div class="smallerCon">
<div class="smallerLeftBoxText">Lorem ipsum dolor sit, amet consectetur adipisicing elit.</div>
</div>
<!-- 可以根据需要添加更多 .smallerCon 元素 -->
</div>为了确保元素的宽度计算符合预期,尤其是在设置边框或内边距时,建议全局设置box-sizing: border-box;。
/* 确保边框和内边距包含在元素的总宽度内 */
* {
box-sizing: border-box;
}我们将分别配置父容器(#container)和子元素(.smallerCon)的Flexbox属性。
堆友
Alibaba Design打造的设计师全成长周期服务平台,旨在成为设计师的好朋友
759
查看详情
父容器是Flexbox的起点,它定义了子元素的排列方式、换行行为以及水平对齐方式。
#container {
width: 90vw; /* 容器宽度,可根据需求调整 */
margin: auto; /* 容器自身水平居中 */
/* Flexbox 属性 */
display: flex; /* 启用 Flexbox 布局 */
flex-flow: row wrap; /* 定义主轴方向为行,并允许子元素换行 */
justify-content: center; /* 子元素在主轴(水平方向)上居中对齐 */
gap: 1rem; /* 子元素之间的间距 */
}子元素需要被配置为在Flex容器中占据合适的宽度,以确保每行显示两个。
.smallerCon {
height: 20vh; /* 子元素高度,可根据需求调整 */
min-width: 18rem; /* [可选] 设置最小宽度,防止在小屏幕上过度收缩 */
/* Flexbox 属性 */
/* flex: <flex-grow> <flex-shrink> <flex-basis>; */
flex: 0 1 calc(50% - 0.5rem); /* 关键属性,控制子元素宽度 */
/* 子元素内部如果还有内容,也可以作为Flex容器 */
display: flex;
flex-flow: row wrap; /* 内部内容也支持换行 */
/* 样式美化 */
background-image: linear-gradient(
to bottom right,
rgba(255, 0, 128, 0.577),
rgba(0, 204, 255, 0.49)
),
url("../img/26March.gif");
object-fit: cover;
background-size: cover;
background-repeat: no-repeat;
background-position: center;
border: 2px solid rebeccapurple;
}.smallerLeftBoxText {
width: 40vw; /* 文本宽度 */
margin: auto; /* 文本自身在 .smallerCon 内部居中 */
font-weight: 400;
color: rgb(245, 223, 223);
}将上述HTML和CSS整合,即可得到一个功能完整的动态两列布局。
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Flexbox动态两列布局与奇数项居中</title>
<style>
/* 全局盒模型设置 */
* {
box-sizing: border-box;
}
body {
font-family: Arial, sans-serif;
margin: 0;
padding: 20px;
background-color: #f4f4f4;
}
/* 父容器样式 */
#container {
width: 90vw; /* 容器宽度 */
margin: 20px auto; /* 容器自身水平居中,并设置上下边距 */
border: 2px dashed #ccc; /* 方便观察容器边界 */
padding: 1rem; /* 容器内边距 */
background-color: #fff;
/* Flexbox 属性 */
display: flex; /* 启用 Flexbox */
flex-flow: row wrap; /* 主轴方向为行,允许换行 */
justify-content: center; /* 子元素在主轴上居中对齐 */
gap: 1rem; /* 子元素之间的间距 */
}
/* 子元素样式 */
.smallerCon {
height: 20vh; /* 子元素高度 */
min-width: 18rem; /* 可选:设置最小宽度,防止小屏幕下过度收缩 */
border: 2px solid rebeccapurple; /* 边框 */
background-image: linear-gradient(
to bottom right,
rgba(255, 0, 128, 0.577),
rgba(0, 204, 255, 0.49)
),
url("https://via.placeholder.com/400x200/FF00FF/FFFFFF?text=Background+Image"); /* 示例背景图 */
background-size: cover;
background-repeat: no-repeat;
background-position: center;
color: rgb(245, 223, 223);
display: flex; /* 使子元素内部内容也能Flex布局 */
align-items: center; /* 垂直居中内部文本 */
justify-content: center; /* 水平居中内部文本 */
text-align: center; /* 文本自身居中 */
/* Flexbox 属性 */
/* flex-grow: 0, flex-shrink: 1, flex-basis: calc(50% - 0.5rem) */
flex: 0 1 calc(50% - 0.5rem); /* 关键:确保每行两列并考虑间距 */
}
.smallerLeftBoxText {
width: 90%; /* 文本占据 .smallerCon 的宽度 */
font-weight: 400;
padding: 10px;
background-color: rgba(0, 0, 0, 0.3); /* 文本背景,增加可读性 */
border-radius: 5px;
}
/* 响应式调整 */
@media (max-width: 768px) {
#container {
width: 95vw;
gap: 0.5rem;
}
.smallerCon {
flex: 0 1 calc(100% - 0.5rem); /* 小屏幕下每行一个 */
min-width: unset; /* 取消最小宽度限制 */
}
}
</style>
</head>
<body>
<div id="container">
<div class="smallerCon">
<div class="smallerLeftBoxText">这是第一个内容块。Flexbox布局实现了动态两列排版。</div>
</div>
<div class="smallerCon">
<div class="smallerLeftBoxText">这是第二个内容块。当空间不足时,元素会自动换行。</div>
</div>
<div class="smallerCon">
<div class="smallerLeftBoxText">这是第三个内容块。如果总数为奇数,最后一个元素会居中。</div>
</div>
<div class="smallerCon">
<div class="smallerLeftBoxText">这是第四个内容块。无需J*aScript,纯CSS即可实现。</div>
</div>
<div class="smallerCon">
<div class="smallerLeftBoxText">这是第五个内容块。因为是奇数,我被居中了!</div>
</div>
<!-- 可以根据需要添加更多 .smallerCon 元素 -->
</div>
</body>
</html>通过上述Flexbox技术,我们能够以纯CSS的方式,高效且灵活地构建出符合动态两列布局需求,并能智能处理奇数项居中显示的UI组件,极大地提升了前端开发的效率和代码的可维护性。
以上就是实现动态两列布局并居中奇数项的CSS Flexbox教程的详细内容,更多请关注其它相关文章!
# javascript
# 宜昌seo收费标准
# 亭湖seo费用
# 百度推广网站谁做
# 中文网
# 这是一个
# 也能
# 最多
# 多个
# 可选
# 只有一个
# 换行
# flex布局
# css
# java
# html
# 前端
# 浏览器
# 工具
# 前端开发
# ai
# 网页设计
# 响应式设计
# 这是
# 濮阳网站建设与设计制作
# 网站综合优化哪家稳妥
# 商品积分营销推广
# 重庆巴南区定制网站建设
# 营销属性视频不能推广吗
# 怎么做餐饮网站推广员呢
# 西安网站建设有哪些优势
相关栏目:
【
Google疑问12 】
【
Facebook疑问10 】
【
优化推广96088 】
【
技术知识133117 】
【
IDC资讯59369 】
【
网络运营7196 】
【
IT资讯61894 】
相关推荐:
德邦快递会员怎么开通
歌词怎么展示在|直播|间视频号?有什么注意事项?
word页码灰色不能用如何解决
《星露谷物语》克林特好感度事件介绍
PHP实现等比数列:构建数组元素基于前一个值递增的方法
手机耗电快是什么原因 延长手机电池续航时间的设置方法【详解】
解决CSS布局中意外顶部空白问题的教程
研招网官方网站正版登录网址_中国研究生招生信息网官网首页
如何查询个人病历记录
PointNet++语义分割模型中类别变更引发的断言错误及标签处理策略
家里的小飞虫总是不断,用什么方法可以彻底根除?
Flexbox布局:实现粘性导航与底部页脚的完美结合
如何定制PrimeNG Sidebar的背景颜色
风神瞳获取全攻略
空腹吃苹果好吗 苹果空腹摄入指南
QQ网站入口直接登录 QQ官方正版登录页面
性能与资源监视器快捷打开
怎样让Windows 11的开始菜单恢复经典样式_Open-Shell工具使用指南【怀旧】
从HTML表单获取逗号分隔值并转换为NumPy数组进行预测
如何发挥新媒体矩阵作用?新媒体矩阵怎么搭建?
《磁力猫》最好用的磁官网
顺丰快递怎么查物流_顺丰快递物流信息实时查询操作指南
济南公交卡手机充值指南
实时数据流中高效查找最小值与最大值
Lar*el Eloquent:高效删除多对多关系中无关联子记录的父模型
拷贝漫画2025网页版入口 拷贝漫画官网免费看全集
智学网app怎么登录忘记密码_智学网app忘记密码找回与重新登录操作方法
Python中深度嵌套字典与列表的数据提取与条件过滤指南
PHP页面重载后变量状态保持:实现用户档案连续浏览的教程
胃动力不足?试试这5个调理方法
NumPy 高性能技巧:基于多列条件查找最近邻行索引的向量化实现
手机雨课堂网页版入口免登录 雨课堂网页版可点击直接进入
安居客移动经纪人怎么设置自动回复?-安居客移动经纪人设置自动回复的方法
抖音网页版官方链接 抖音网页版官网链接入口
抖音商城官网是什么_抖音商城官方网址与访问方法
深入理解Python对象引用与链表属性赋值
《海底捞》点外卖方法
鲁班大师乓乓皮肤获取方法
银信通自动开通原因揭秘
c++如何使用std::thread::join和detach_c++线程生命周期管理
折叠屏手机充不进电是什么问题? 特殊结构带来的维修难点
解决Pandas DataFrame高度碎片化警告:高效创建多列的策略
win11怎么更改账户类型 Win11标准用户和管理员权限切换【教程】
windows10怎么设置电源按钮_windows10按下电源键功能修改
SQLAlchemy 2.0 与 Pydantic 模型类型安全集成指南
《顺丰同城骑士》查看我的技能方法
解决Go encoding/json 将JSON大数字解析为浮点数的问题
解决PHP MySQL数据库更新无响应:SQL查询语法错误解析
使用AI在VS Code中将代码从一种语言翻译成另一种
QQ网页版官方账号登录入口 QQ网页版网页版入口快速导航
2025-12-07
运城市盐湖区信雨科技有限公司是一家深耕海外推广领域十年的专业服务商,作为谷歌推广与Facebook广告全球合作伙伴,聚焦外贸企业出海痛点,以数字化营销为核心,提供一站式海外营销解决方案。公司凭借十年行业沉淀与平台官方资源加持,打破传统外贸获客壁垒,助力企业高效开拓全球市场,成为中小企业出海的可靠合作伙伴。