侧边栏收缩布局怎么实现_借助flex动态调整宽度
发布时间 - 2025-12-29 00:00:00 点击率:次侧边栏收缩布局用 Flex 实现,核心是类名切换控制 width + transition 动画,主内容区设 flex: 1 和 min-width: 0,侧边栏设初始 width、min-width: 0 且不设 flex-shrink: 0;收缩时通过 .sidebar-collapsed 切换 width 和 overflow,图标保留、文字 opacity/width 归零;小屏下媒体查询隐藏侧边栏,汉堡菜单以 fixed 覆盖层唤出。
侧边栏收缩布局用 Flex 实现,核心是利用 flex 的弹性行为 + 类名切换控制宽度,配合 CSS 过渡实现平滑收放效果,无需 JS 计算尺寸。
基础结构:用 flex-direction: row 搭建主-侧布局
容器设为 display: flex,主内容区用 flex: 1 自适应剩余空间,侧边栏设初始宽度(如 width: 260px)并允许收缩:
- 侧边栏不写
flex: 0 0 auto(默认即可),但需加min-width: 0防止内容撑宽 - 主内容区必须设
min-width: 0,否则文字或长单词可能破坏收缩逻辑 - 避免在侧边栏上直接写
flex-basis和flex-shrink: 0,否则无法压缩
收缩控制:用 class 切换触发宽度变化
定义一个 .sidebar-collapsed 类,只改侧边栏的 width 和 overflow,不碰 flex 属性:
.sidebar { width: 260px; transition: width 0.3s ease; }.sidebar-collapsed { width: 60px; overflow: hidden; }- JS 只负责增删该 class,不操作 style 或 offsetWidth
图标与文字的响应式显示
侧边栏内元素根据宽度自动显隐,不用媒体查询:
- 文字用
span包裹,初始opacity: 1; width: auto; - 收缩时加
.sidebar-collapsed span { opacity: 0; width: 0; },再配overflow: hidden - 图标保持显示,可加
flex-shrink: 0防被压缩变形
适配移动端:折叠后隐藏侧边栏
小屏下直接隐藏侧边栏,用汉堡菜单唤出:
- 媒体查询中设
@media (max-width: 768px) { .sidebar { display: none; } } - 点击按钮时给 body 加
sidebar-open类,用position: fixed覆盖层展示 - 此时 flex 布局退化为主内容区占满全屏,逻辑更清晰
# css
# js
# overflow
# auto
# class
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel路由Route怎么设置_Laravel基础路由定义与参数传递规则【详解】
郑州企业网站制作公司,郑州招聘网站有哪些?
LinuxShell函数封装方法_脚本复用设计思路【教程】
Zeus浏览器网页版官网入口 宙斯浏览器官网在线通道
laravel怎么实现图片的压缩和裁剪_laravel图片压缩与裁剪方法
实例解析angularjs的filter过滤器
教学论文网站制作软件有哪些,写论文用什么软件
?
Win11怎么修改DNS服务器 Win11设置DNS加速网络【指南】
lovemo网页版地址 lovemo官网手机登录
如何在阿里云ECS服务器部署织梦CMS网站?
如何在云主机上快速搭建多站点网站?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
Android滚轮选择时间控件使用详解
Laravel如何优化应用性能?(缓存和优化命令)
在centOS 7安装mysql 5.7的详细教程
如何在阿里云高效完成企业建站全流程?
如何挑选高效建站主机与优质域名?
什么是JavaScript解构赋值_解构赋值有哪些实用技巧
如何在阿里云香港服务器快速搭建网站?
Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载
免费网站制作appp,免费制作app哪个平台好?
香港服务器租用费用高吗?如何避免常见误区?
制作电商网页,电商供应链怎么做?
Laravel怎么实现验证码(Captcha)功能
Laravel如何处理CORS跨域请求?(配置示例)
Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程
Windows10电脑怎么设置虚拟光驱_Win10右键装载ISO镜像文件
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】
魔方云NAT建站如何实现端口转发?
今日头条微视频如何找选题 今日头条微视频找选题技巧【指南】
如何在建站主机中优化服务器配置?
Laravel怎么实现软删除SoftDeletes_Laravel模型回收站功能与数据恢复【步骤】
开心动漫网站制作软件下载,十分开心动画为何停播?
如何快速搭建支持数据库操作的智能建站平台?
极客网站有哪些,DoNews、36氪、爱范儿、虎嗅、雷锋网、极客公园这些互联网媒体网站有什么差异?
EditPlus中的正则表达式 实战(4)
网页设计与网站制作内容,怎样注册网站?
ChatGPT 4.0官网入口地址 ChatGPT在线体验官网
Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
网站制作软件免费下载安装,有哪些免费下载的软件网站?
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
HTML5空格在Angular项目里怎么处理_Angular中空格的渲染问题【详解】
如何用y主机助手快速搭建网站?
php在windows下怎么调试_phpwindows环境调试操作说明【操作】
Python自动化办公教程_ExcelWordPDF批量处理案例
Laravel如何保护应用免受CSRF攻击?(原理和示例)
Win11怎样安装网易有道词典_Win11安装词典教程【步骤】
详解Nginx + Tomcat 反向代理 负载均衡 集群 部署指南
Laravel如何生成API文档?(Swagger/OpenAPI教程)


边栏,汉堡菜单以 fixed 覆盖层唤出。