【前端】侧边栏收缩的优化

简介: 【前端】侧边栏收缩的优化

继上一篇文章【前端】侧边栏显示隐藏的实现和动画效果

发现了一个bug:当展开侧边栏,拉大窗口(大尺寸的窗口状态是不显示侧边栏控制按钮的),于是这个侧边栏就回不去了。

于是我想到了一个办法,增加一个遮罩层。使页面侧边栏展开时,除了侧边栏,便是遮罩层。点击遮罩层,则隐藏侧边栏。

HTML关键代码如下

<!--遮罩层-->
 <div class="mubu" id="mubu" onclick="menuNotShow();return false;">
<!--侧边栏-->
 </div>
        <div class="box-left-menu" id="left-menu">
            <div class="title">
                萌狼工作室
                <hr>
            </div>
        <div>
            <ul>
                <li><a href="#">首页</a></li>
                <li><a href="#">资源</a></li>
                <li><a href="#">网站</a></li>
                <li><a href="#">关于</a></li>
            </ul>
        </div>
        </div>

相关CSS样式

header .box-left-menu{
    /*从文档流完全删除,并相对于其包含块定位*/
    position: absolute;
    left:-10em;
    top:0;
    z-index:9999;
    width:10em;
    height: 100%;
    background-color: var(--background-color);
    box-shadow: 1px 1px 1px 1px var(--shadow-color);
    /*transition: transition-property transition-duration transition-timing-function transition-delay;*/
    transition: all 0.7s ease 0ms;
    opacity: 0;
}
header .mubu{
    position: absolute;
    width: 100%;
    height: 100%;
    /*优先级比左侧菜单栏低一级*/
    z-index:9998;
    background-color: var(--shadow-color);
    opacity: 0;
}

相关js

function menuShow(){
    let item = document.getElementById("left-menu");
    let mubu = document.getElementById("mubu");
    if(item.style.left==="0px"){
        item.style.left="-10em"
        item.style.opacity="0"
        mubu.style.opacity="0"
    }else{
        item.style.left="0px"
        item.style.opacity="1"
        mubu.style.opacity="1"
    }
}
function menuNotShow(){
    let item = document.getElementById("left-menu");
    let mubu = document.getElementById("mubu");
    item.style.left="-10em"
    item.style.opacity="0"
    mubu.style.opacity="0"
}
相关文章
|
4天前
|
缓存 前端开发 搜索推荐
如何优化前端性能:提升网页加载速度的5个技巧
在当今互联网时代,网页加载速度是用户体验和搜索引擎排名的关键因素之一。本文将介绍5个有效的技巧,帮助前端开发人员优化网页性能,提升用户体验。
|
19天前
|
前端开发 JavaScript 开发者
优化前端性能的关键技巧与实践
在当今互联网时代,前端性能优化是网站和应用开发中至关重要的一环。本文将介绍一些关键的前端性能优化技巧,并提供实际的实践案例,帮助开发者有效提升网站和应用的性能表现。
|
1天前
|
缓存 监控 前端开发
【Flutter 前端技术开发专栏】Flutter 应用的启动优化策略
【4月更文挑战第30天】本文探讨了Flutter应用启动优化策略,包括理解启动过程、资源加载优化、减少初始化工作、界面布局简化、异步初始化、预加载关键数据、性能监控分析以及案例和未来优化方向。通过这些方法,可以缩短启动时间,提升用户体验。使用Flutter DevTools等工具可助于识别和解决性能瓶颈,实现持续优化。
【Flutter 前端技术开发专栏】Flutter 应用的启动优化策略
|
1天前
|
存储 缓存 前端开发
【Flutter前端技术开发专栏】Flutter中的图片加载与缓存优化
【4月更文挑战第30天】本文探讨了 Flutter 中如何优化图片加载与缓存,以提升移动应用性能。通过使用图片占位符、压缩裁剪、缓存策略(如`cached_network_image`插件)以及异步加载和预加载图片,可以显著加快加载速度。此外,利用`FadeInImage`、`FutureBuilder`和图片库等工具,能进一步改善用户体验。优化图片处理是提升Flutter应用效率的关键,本文为开发者提供了实用指导。
【Flutter前端技术开发专栏】Flutter中的图片加载与缓存优化
|
1天前
|
缓存 前端开发 数据安全/隐私保护
【Flutter 前端技术开发专栏】Flutter 中的键盘处理与输入框优化
【4月更文挑战第30天】本文探讨了Flutter中键盘处理与输入框优化的关键技术,包括监听键盘显示隐藏、焦点管理、键盘类型适配、输入框高度自适应、处理键盘遮挡问题及性能优化。通过使用WidgetsBindingObserver、FocusNode和TextInputType等工具,开发者能提升用户体验,确保输入框在各种场景下的良好表现。实例分析和实践建议有助于开发者将这些方法应用于实际项目。
【Flutter 前端技术开发专栏】Flutter 中的键盘处理与输入框优化
|
1天前
|
前端开发 UED 开发者
【Flutter前端技术开发专栏】Flutter中的列表与滚动视图优化
【4月更文挑战第30天】Flutter开发中,优化列表和滚动视图至关重要。本文介绍了几种优化方法:1) 使用`ListView.builder`和`GridView.builder`实现懒加载;2) 复用子组件以减少实例创建;3) 利用`CustomScrollView`和`Slivers`提升滚动性能;4) 通过`NotificationListener`监听滚动事件;5) 使用`KeepAlive`保持列表项状态。掌握这些技巧能提升应用性能和用户体验。
【Flutter前端技术开发专栏】Flutter中的列表与滚动视图优化
|
1天前
|
缓存 前端开发 JavaScript
如何优化前端性能:关键技巧与最佳实践
在当今数字化时代,前端性能优化是构建高效用户体验的关键。本文探讨了一系列关键技巧和最佳实践,帮助开发人员提升前端应用的性能表现。从资源加载到代码优化,从图片处理到网络请求,我们将深入探讨如何通过各种手段使前端应用更加高效。
|
2天前
|
前端开发 JavaScript 网络协议
【专栏】前端性能优化之 Performance 神器
【4月更文挑战第29天】本文探讨了前端性能优化中的 Performance 工具,它能帮助开发者分析页面加载速度和交互体验。通过 Performance,可检测资源加载时间、JavaScript 执行时间、重绘与回流等关键指标,找到性能瓶颈。文中列举了三个实践案例,如优化图片加载、减少 JavaScript 执行时间和避免重绘回流,展示如何利用 Performance 改进页面性能,提升用户体验。开发者应定期使用 Performance 分析并学习新优化技术,以适应Web开发的快速发展。
|
3天前
|
缓存 前端开发 算法
前端需要加载一个大体积的文件时,可以这么优化
前端需要加载一个大体积的文件时,可以这么优化
|
3天前
|
缓存 前端开发 JavaScript
如何优化前端网页加载速度:实用技巧大揭秘
在当今互联网时代,快速加载的网页是用户体验的关键。本文将介绍一些实用的前端优化技巧,从减少HTTP请求到使用CDN加速,帮助开发人员提高网页加载速度,提升用户满意度。