vue中将侧边栏隐藏
对于一些系统网站,我们通常都会存在侧边导航栏,有些场景下,我们需要将它隐藏掉,那要如何实现呢?
这里记录一种思路:
我们可以通过小图标的点击,实现隐藏和展开。 主要原理就是 利用leftWidth变量动态设置css样式
我们分别找到两个小图标,对应点击展开和点击隐藏。
然后给左侧导航栏和右侧主界面动态的设置css样式(初始leftWidth为18,也就是左侧导航栏的宽度占比)
<template>
<div class="root">
<div class="container">
<img src="./assets/images/rightbar.png" alt="" title="点击展开" v-if="this.leftWidth<2" @click="openList" class="menu_Open">
<!-- menu_list 列表 -->
<div class="list" :style="{width: leftWidth + '%'}">
<img src="./assets/images/leftbar.png" title="点击收起" alt="" class="menu_Close" @click="closeList">
<div v-for="item in menu_list" :key="item.id">{{item.id}} - {{item.name}}</div>
</div>
<!-- main 页面 -->
<div :style="{width: (100 - leftWidth) + '%'}" class="mainPage">
<h1>This is the Main Page!</h1>
</div>
</div>
</div>
</template>
<script>
export default {
name: 'App',
components:{
},
data(){
return {
leftWidth: 18,
menu_list: [
{
id: 1,
name: '列表1'
},
{
id: 2,
name: '列表2'
},
{
id: 3,
name: '列表3'
},
]
}
},
methods: {
openList(){
this.leftWidth = 18
console.log('open',this.leftWidth);
},
closeList(){
this.leftWidth = 0;
console.log('close',this.leftWidth);
}
}
}
</script>
<style>
html,body {
margin: 0;
padding: 0;
width: 100%;
height: 100%;
}
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
height: 100%;
width: 100%;
background: gray;
}
.root {
height: 100%;
}
.container {
display: flex;
position: relative;
height: 100%;
text-align: center;
}
/* 侧边导航栏 */
.list {
border-right: 1px solid rgb(64, 85, 122);
padding-top: 10px;
box-sizing: border-box;
height: 100%;
position: relative;
overflow: hidden;
}
/* 关闭侧边栏 小图标 */
.menu_Close {
width: 20px;
height: 20px;
position: absolute;
right: 0;
top: 10px;
opacity: 0.7;
cursor: pointer;
}
/* 展开侧边栏 小图标 */
.menu_Open {
width: 20px;
height: 20px;
position: absolute;
left: 0;
top: 10px;
opacity: 0.7;
cursor: pointer;
z-index: 99999;
}
/* 右侧主要页面 */
.mainPage {
padding: 10px;
}
</style>
也可以修改各个值的参数来自定义布局,比如 左侧导航栏展开和隐藏后的宽度,可以通过leftWidth设置, 小图标的具体位置,可以通过left和top的值设置