[vue3] 菜单动态折叠效果

 ✨✨个人主页:沫洺的主页

📚📚系列专栏: 📖 JavaWeb专栏📖 JavaSE专栏 📖 Java基础专栏📖vue3专栏 

                           📖MyBatis专栏📖Spring专栏📖SpringMVC专栏📖SpringBoot专栏

                           📖Docker专栏📖Reids专栏📖MQ专栏📖SpringCloud专栏     

💖💖如果文章对你有所帮助请留下三连✨✨

🍔前言

🍿本章是衔接上一篇文章进行的,可去vue3专栏中找到

🍿饿了么Plus:网址

🍟效果图

🌭 实现内容

  • 🍿ElementPuls页面布局(上一章)
  • 🍿动态菜单显示(上一章)
  • 🍿实现菜单折叠效果(本章)
  • 🍿实现部分页面不使用整体框架(下一章)
  • 🍿统一页面导航标签(下一章)

🍕实现菜单折叠效果

 

 

🍖设置关闭折叠动画,默认展开,添加图标点击事件控制是否折叠,解决折叠时卡顿问题

使用水平折叠,默认false不折叠,关闭自带的折叠动画

🍖 接下来通过图标来控制是否折叠

    <!-- 行 -->
    <el-row class="btbg">
        <!-- 列 -->
        <!-- offset偏移量 span占位-->
        <el-col :offset="9" :span="6">
            <!-- 图标 -->
            <el-icon @click="openOrClose" v-if="!isCollapse">
                <Fold />
            </el-icon>
            <!-- 图标 -->
            <el-icon @click="openOrClose" v-if="isCollapse">
                <Expand />
            </el-icon>
        </el-col>
    </el-row>

🍖解决折叠时卡顿问题

🍖在点击时会发现有点卡顿,原因是这个组件有bug,解决方法就是修改内部样式,注意将之前的class="el"改为了class="el-menu-vertical-demo"

.el-menu-vertical-demo {
    background-color: #b2b6b6;
}

.el-menu-vertical-demo:not(.el-menu--collapse) {
    height: 90%;
    min-height: calc(100vh - 100px);
}

.el-menu--collapse {
    min-height: calc(100vh - 100px);
}

🍖效果图

🍖 如果上图所示的缝隙问题可通过style="height:calc(100vh - 76px)"设置,根据自己的网页进行调整

🍖折叠时有一个问题,如下图所示,预期的结果应该时让Main部分自动填充空白区域,解决办法就是动态修改Aside部分的宽度,用到的技术就是消息订阅于发布

🍖 来看效果

🍖 接下来就是锦上添花了,给控制展开的图标添加样式

.btbg {
    background-color: #aab3bb;
    color: white;
    cursor: pointer;
    /* height: 20px; */
    /* padding-top: 10px; */
}

🍖 给Main部分添加底色

🍖 完事

🍕总结说明

🍖其他部分放到下一章,实现部分页面不使用整体框架,统一页面导航标签

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

沫洺

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值