当前位置: 代码网 > it编程>前端脚本>Vue.js > vue2左侧菜单栏收缩展开功能实现

vue2左侧菜单栏收缩展开功能实现

2024年05月26日 Vue.js 我要评论
vue2左侧菜单栏收缩展开目前是非常常见的,我们在日常开发过程中经常会碰到。这一小节我们就详细了解一下这个功能,完善我们的项目开发。首先,修改main.vue页面中的一些属性,有些属性需要动态绑定。接

vue2左侧菜单栏收缩展开目前是非常常见的,我们在日常开发过程中经常会碰到。这一小节我们就详细了解一下这个功能,完善我们的项目开发。

首先,修改main.vue页面中的一些属性,有些属性需要动态绑定。接下来我们来一步一步实现。

1. main.vue页面代码

a. 修改侧边栏属性

我们给我们导入的aside组件动态绑定一个iscollapse。然后再下面的方法中定义

logotextshow是我们动态绑定的系统名称:当我们点击收缩菜单时,系统名称会隐藏,展示我们的系统图标。

下面是效果展示:

<!--其它代码-->
<!-- 侧边栏 -->
<el-aside :width="sidewidth + 'px'" style="background-color: rgb(238, 241, 246);height: 100%">
  <aside :iscollapse="iscollapse" :logotextshow="logotextshow"/>
</el-aside>
<!--其它代码-->

b. 修改头部导航栏

头部导航栏是我们点击收缩展开按钮的地方,我们在这里动态绑定点击函数。collapse函数就是我们动态绑定的函数。

<!--其它代码-->
<!-- 头部导航栏 -->
<el-header style="border-bottom: 1px solid #ccc;">
  <header :collapsebtnclass="collapsebtnclass" :collapse="collapse"/>
</el-header>
<!--其它代码-->

c. 定义我们的变量

我们在return中定义我们的collapsebtnclass图标变量;

定义aside.vue中的sidewidth左侧菜单栏宽度

还有默认展示我们的系统名称而不是展示logo图片

<!--其它代码-->
data () {
  return {
    collapsebtnclass: 'el-icon-s-fold',
    iscollapse: false,
    sidewidth: 220,
    logotextshow: true
  }
},
<!--其它代码-->

d. collapse函数

这里我们函数的逻辑是:

当我们点击收缩菜单图标时,iscollapse变量为flase;

当我们的iscollapse变量为false时,this.sidewidth宽度为64,图标设置为收缩图标

然后我们的系统名称隐藏;

相反:我们的菜单宽度为220;设置展开图标,系统名称菜单展示

<!--其它代码-->
methods: {
  collapse () {
    this.iscollapse = !this.iscollapse
    if (this.iscollapse) {
      this.sidewidth = 64
      this.collapsebtnclass = 'el-icon-s-unfold'
      this.logotextshow = false
    } else {
      this.sidewidth = 220
      this.collapsebtnclass = 'el-icon-s-fold'
      this.logotextshow = true
    }
  }
}
<!--其它代码-->

2. header.vue页面代码

首先在我们面包屑上面加一个span标签:

绑定我们的class为collapsebtnclass:

设置一个点击事件:collapse

<!--其它代码-->
<span :class="collapsebtnclass" style="cursor: pointer; font-size: 18px" @click="collapse"></span>
<!--其它代码-->

这里牵扯到一个父子传值和子子传值。父子传值我们在子组件里面接收就要用props来接收

<!--其它代码-->
props: {
  collapsebtnclass: string,
  collapse: function
}
<!--其它代码-->

3. aside.vue页面代码

我们在标签<el-menu>绑定我们的属性:

<el-menu
    :default-openeds="[]" style="min-height: 100%; overflow-x: hidden"
    background-color="#1f2d3d"
    text-color="#fff"
    default-active="/home"
    active-text-color="rgb(75 175 255)"
    :collapse-transition="false"
    :collapse="iscollapse"
    router>

系统名称给一个v-show事件

<div style="height: 60px; line-height: 60px; text-align: center">
  <img src="../assets/logo.png" alt="" style="width: 20px; position: relative; top: 2px;">
  <b style="color: white" v-show="logotextshow">仓库管理系统</b>
</div>

然后我们在下面接收父组件传递的值:

<!--其它代码-->
props: {
  iscollapse: boolean,
  logotextshow: boolean
}
<!--其它代码-->

现在会有一个问题,我们点击收缩菜单栏时菜单文字会有遗留,我们给一个样式来隐藏文字

<style>
.el-menu-item.is-active {
  background-color: rgb(38, 52, 69) !important;
}
.el-menu-item:hover {
  background-color: rgb(38, 52, 69) !important;
}
.el-submenu__title:hover {
  background-color: rgb(38, 52, 69) !important;
}
/*解决收缩菜单文字不消失问题*/
.el-menu--collapse span {
  visibility: hidden;
}
</style>

以上就是我们的菜单栏收缩展开全部教程。

到此这篇关于vue2左侧菜单栏收缩展开功能的文章就介绍到这了,更多相关vue2菜单栏收缩展开内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com