侧边栏收缩布局怎么实现_借助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-basisflex-shrink: 0,否则无法压缩

收缩控制:用 class 切换触发宽度变化

定义一个 .sidebar-collapsed 类,只改侧边栏的 widthoverflow,不碰 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教程)