el-menu官方文档:Element - The world's most popular Vue UI frameworkElement,一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库 https://element.eleme.cn/#/zh-CN/component/menu?参考:vue后台管理系统布局模板_~疆的博客-CSDN博客_vue 后台管理系统模板类似以下这种布局,其中,Aside板块可以展开/收缩结构目录:home.vue:<!--home.vue--><template> <div class="homeContainer"> <div class="header"> <img src="@/assets/logo.png" style="height:70px;width:55px;margin-left:30px;" /> . https://blog.csdn.net/qq_40323256/article/details/114650131
vue顶部菜单栏积累_~疆的博客-CSDN博客参考:Elementui中El-menu导航栏_~疆的博客-CSDN博客_element 导航栏https://blog.csdn.net/qq_40323256/article/details/125212606 效果图2: https://blog.csdn.net/qq_40323256/article/details/125324396data:image/s3,"s3://crabby-images/94647/94647c1db54182ea253d2b15376c3f5a695f7690" alt="" ??data:image/s3,"s3://crabby-images/58e41/58e41e1cee8b591e398751f2ebcd523e9fa7c443" alt=""
注意:竖着时,要加上样式:class="el-menu-vertical-demo",否则竖着展开时的宽度会设置失败
导航栏垂直时去除右侧白边:
data:image/s3,"s3://crabby-images/f4102/f41022fa52cba086db96b19d098e25ea7d5a5ad8" alt=""
.el-menu {
border: 0 !important; //垂直时,去除右侧白边
}
?导航栏水平时去除底部白边:
data:image/s3,"s3://crabby-images/ba708/ba708c69830f0a93f2b4cce6cbd3757b1ab3ab03" alt=""
注意:水平时去除底部白边是用的新添加的style标签实现的。其他方式不行,如用::deep,或者直接在原来的style中改,都不行
<style>
/* 水平时,去除底部白边。 */
.el-menu.el-menu--horizontal {
border-bottom: 0;
}
</style>
注意:如果设置了还是有白边的话,如下:
data:image/s3,"s3://crabby-images/2342f/2342fbf5230eaa96f7c2d7c794b7cdb55296dad9" alt=""
?有可能是右侧的el-dropdown造成的,将el-dropdown样式设置line-height:0即可消除白色间隙
data:image/s3,"s3://crabby-images/81883/81883c13a9ec2c690aadc1512c560aa79da7834b" alt="" data:image/s3,"s3://crabby-images/10c76/10c7606c0975e2bf57934dd595638e751dbffa20" alt=""
菜单切换时取消过渡效果:
一定要新添加一个style标签!!!!
data:image/s3,"s3://crabby-images/33bf7/33bf71a8843766eba7d658404ce7dfb107109c73" alt=""
<style>
/* 取消过渡效果 */
.el-menu-item {
transition-duration: 0s;
}
</style>
?侧边栏展开时宽度:
前提:加上样式?class="el-menu-vertical-demo"?
.el-menu-vertical-demo:not(.el-menu--collapse) {
width: 256px;
}
侧边栏折叠时宽度:
//折叠时宽度
.el-menu--collapse {
width: 110px;
}
?菜单选中时设置背景色:
.el-menu-item.is-active {
background-color: #1890ff !important;
}
此外还可设置其他样式,如下:
data:image/s3,"s3://crabby-images/e68c2/e68c2b6d896114204f6e62aff1a96df09634fcd5" alt=""
data:image/s3,"s3://crabby-images/b9b1d/b9b1d17948e3182f611400c196480299dec54e79" alt=""
选中时取消显示底部横线:
data:image/s3,"s3://crabby-images/a7ba3/a7ba35cf06d893fd2353330d955d478d7b57e594" alt="" data:image/s3,"s3://crabby-images/3edbd/3edbd0eabbc996cfbe08a11bdb934753ebb7d285" alt="" data:image/s3,"s3://crabby-images/04e40/04e404196c759c6d69f08ecb148a84414542773f" alt=""
菜单hover时设置字体颜色:
data:image/s3,"s3://crabby-images/14ec3/14ec30f2cc8a67339b5b50130f79de60fb7c8481" alt=""
.el-menu-item:hover {
color: white !important;
}
当然也可设置背景色
data:image/s3,"s3://crabby-images/71a18/71a18ee7d3ae83f14f00f14f567e7258a36d3f0f" alt="" data:image/s3,"s3://crabby-images/4d13e/4d13efe0fea4a64a0e6a08df8a0961342b059590" alt=""
示例:
data:image/s3,"s3://crabby-images/4087c/4087cf6f99d07c9d84b32b21997a9da091130f14" alt="" data:image/s3,"s3://crabby-images/f8863/f88635e598442a00238ec7d63712b3d250e1499c" alt=""
<template>
<div class="aside">
<div class="aside-header">
<img
src="https://lj-common.oss-cn-chengdu.aliyuncs.com/vue.png"
style="width: 30px; height: 30px"
/>
<span
style="
font-size: 20px;
font-weight: 600;
color: white;
margin-left: 10px;
"
>xxx平台</span
>
</div>
<div class="aside-menu">
<perfect-scrollbar>
<el-menu
:default-active="$route.path"
class="el-menu-vertical-demo"
background-color="#191A23"
text-color="#D1D1D3"
active-text-color="white"
unique-opened
>
<el-menu-item
index="/download"
@click="$router.push({ path: '/download' })"
>
<i class="el-icon-location"></i>
<span slot="title">首页</span>
</el-menu-item>
<el-menu-item index="/test" @click="$router.push({ path: '/test' })">
<i class="el-icon-location"></i>
<span slot="title">test</span>
</el-menu-item>
<el-submenu index="1">
<template slot="title">
<i class="el-icon-location"></i>
<span>导航一</span>
</template>
<el-menu-item index="1-3">选项3</el-menu-item>
<el-submenu index="1-4">
<template slot="title">选项4</template>
<el-menu-item index="1-4-1">选项1</el-menu-item>
</el-submenu>
</el-submenu>
<el-submenu index="2">
<template slot="title">
<i class="el-icon-location"></i>
<span>导航2</span>
</template>
<el-menu-item index="2-3">选项5</el-menu-item>
</el-submenu>
</el-menu>
</perfect-scrollbar>
</div>
</div>
</template>
<script>
export default {
data() {
return {};
},
methods: {},
watch: {},
};
</script>
<style lang='scss' scoped>
.aside {
height: 100vh;
.aside-header {
height: 60px;
background-color: #191a23;
line-height: 60px;
display: flex;
align-items: center;
justify-content: center;
}
.aside-menu {
height: calc(100vh - 60px);
//perfect-scrollbar默认的类名。自定义滚动条内容区域高度
.ps {
height: 100%;
//展开时宽度
.el-menu-vertical-demo:not(.el-menu--collapse) {
width: 256px;
}
//折叠时宽度
// .el-menu--collapse {
// width: 110px;
// }
.el-menu {
height: 100%;
border: 0 !important; //垂直时,去除右侧白边
.el-menu-item:hover {
color: white !important;
}
}
.el-menu-item.is-active {
background-color: #1890ff !important;
}
}
}
}
</style>
data:image/s3,"s3://crabby-images/f839f/f839f5ce68b8b106f42c292499effade43c191eb" alt=""
<el-menu
default-active="2-4-2"
mode="horizontal"
background-color="#017bc4"
text-color="white"
active-text-color="orange"
style="margin-left: 30px"
>
<el-menu-item index="1">首页</el-menu-item>
<el-submenu index="2">
<template slot="title">测试</template>
<el-menu-item index="2-1">选项1</el-menu-item>
<el-menu-item index="2-2">选项2</el-menu-item>
<el-menu-item index="2-3">选项3</el-menu-item>
<el-submenu index="2-4">
<template slot="title">选项4</template>
<el-menu-item index="2-4-1">选项1</el-menu-item>
<el-menu-item index="2-4-2">选项2</el-menu-item>
<el-menu-item index="2-4-3">选项3</el-menu-item>
</el-submenu>
</el-submenu>
<el-menu-item index="3" disabled>消息中心</el-menu-item>
</el-menu>
|