|
1 | 1 | <template>
|
2 | 2 | <el-row class="container">
|
3 | 3 | <el-col :span="24" class="header">
|
4 |
| - <el-col :span="20" class="logo"> |
5 |
| - VUEADMIN |
| 4 | + <el-col :span="10" class="logo" :class="collapsed?'logo-collapse-width':'logo-width'"> |
| 5 | + {{collapsed?'':sysName}} |
| 6 | + </el-col> |
| 7 | + <el-col :span="10"> |
| 8 | + <div class="tools" @click.prevent="collapse"> |
| 9 | + <i class="fa fa-align-justify"></i> |
| 10 | + </div> |
6 | 11 | </el-col>
|
7 | 12 | <el-col :span="4" class="userinfo">
|
8 | 13 | <el-dropdown trigger="click">
|
|
16 | 21 | </el-col>
|
17 | 22 | </el-col>
|
18 | 23 | <el-col :span="24" class="main">
|
19 |
| - <aside> |
| 24 | + <aside :class="collapsed?'menu-collapsed':'menu-expanded'"> |
| 25 | + <!--导航菜单--> |
20 | 26 | <el-menu :default-active="$route.path" class="el-menu-vertical-demo" @open="handleopen" @close="handleclose" @select="handleselect"
|
21 |
| - unique-opened router> |
| 27 | + unique-opened router v-show="!collapsed"> |
22 | 28 | <template v-for="(item,index) in $router.options.routes" v-if="!item.hidden">
|
23 | 29 | <el-submenu :index="index+''" v-if="!item.leaf">
|
24 | 30 | <template slot="title"><i :class="item.iconCls"></i>{{item.name}}</template>
|
25 | 31 | <el-menu-item v-for="child in item.children" :index="child.path" v-if="!child.hidden">{{child.name}}</el-menu-item>
|
26 | 32 | </el-submenu>
|
27 | 33 | <el-menu-item v-if="item.leaf&&item.children.length>0" :index="item.children[0].path"><i :class="item.iconCls"></i>{{item.children[0].name}}</el-menu-item>
|
28 | 34 | </template>
|
29 |
| - </el-menu> |
| 35 | + </el-menu> |
| 36 | + <!--导航菜单-折叠后--> |
| 37 | + <ul class="el-menu el-menu-vertical-demo collapsed" v-show="collapsed" ref="menuCollapsed"> |
| 38 | + <li v-for="(item,index) in $router.options.routes" v-if="!item.hidden" class="el-submenu item"> |
| 39 | + <template v-if="!item.leaf"> |
| 40 | + <div class="el-submenu__title" style="padding-left: 20px;" @mouseover="showMenu(index,true)" @mouseout="showMenu(index,false)"><i :class="item.iconCls"></i></div> |
| 41 | + <ul class="el-menu submenu" :class="'submenu-hook-'+index" @mouseover="showMenu(index,true)" @mouseout="showMenu(index,false)"> |
| 42 | + <li v-for="child in item.children" v-if="!child.hidden" class="el-menu-item" style="padding-left: 40px;" :class="$route.path==child.path?'is-active':''" @click="$router.push(child.path)">{{child.name}}</li> |
| 43 | + </ul> |
| 44 | + </template> |
| 45 | + <template v-else> |
| 46 | + <li class="el-submenu"> |
| 47 | + <div class="el-submenu__title el-menu-item" style="padding-left: 20px;height: 56px;line-height: 56px;padding: 0 20px;" :class="$route.path==item.children[0].path?'is-active':''" @click="$router.push(item.children[0].path)"><i :class="item.iconCls"></i></div> |
| 48 | + </li> |
| 49 | + </template> |
| 50 | + </li> |
| 51 | + </ul> |
30 | 52 | </aside>
|
31 | 53 | <section class="content-container">
|
32 | 54 | <div class="grid-content bg-purple-light">
|
|
53 | 75 | export default {
|
54 | 76 | data() {
|
55 | 77 | return {
|
| 78 | + sysName:'VUEADMIN', |
| 79 | + collapsed:false, |
56 | 80 | sysUserName: '',
|
57 | 81 | sysUserAvatar: '',
|
58 | 82 | form: {
|
|
92 | 116 | });
|
93 | 117 |
|
94 | 118 |
|
| 119 | + }, |
| 120 | + //折叠导航栏 |
| 121 | + collapse:function(){ |
| 122 | + this.collapsed=!this.collapsed; |
| 123 | + }, |
| 124 | + showMenu(i,status){ |
| 125 | + this.$refs.menuCollapsed.getElementsByClassName('submenu-hook-'+i)[0].style.display=status?'block':'none'; |
95 | 126 | }
|
96 | 127 | },
|
97 | 128 | mounted() {
|
|
101 | 132 | this.sysUserName = user.name || '';
|
102 | 133 | this.sysUserAvatar = user.avatar || '';
|
103 | 134 | }
|
| 135 | +
|
104 | 136 | }
|
105 | 137 | }
|
106 | 138 |
|
|
115 | 147 | .header {
|
116 | 148 | height: 60px;
|
117 | 149 | line-height: 60px;
|
118 |
| - background: #18c79c;//#20a0ff |
| 150 | + background: #20a0ff;//#20a0ff |
119 | 151 | color:#fff;
|
120 | 152 | .userinfo {
|
121 | 153 | text-align: right;
|
122 | 154 | padding-right: 35px;
|
| 155 | + float: right; |
123 | 156 | .userinfo-inner {
|
124 | 157 | cursor: pointer;
|
125 | 158 | color:#fff;
|
|
133 | 166 | }
|
134 | 167 | }
|
135 | 168 | .logo {
|
| 169 | + //width:230px; |
| 170 | + height:60px; |
136 | 171 | font-size: 22px;
|
137 | 172 | padding-left:20px;
|
| 173 | + padding-right:20px; |
| 174 | + border-color: rgba(238,241,146,0.3); |
| 175 | + border-right-width: 1px; |
| 176 | + border-right-style: solid; |
138 | 177 | img {
|
139 | 178 | width: 40px;
|
140 | 179 | float: left;
|
|
144 | 183 | color:#fff;
|
145 | 184 | }
|
146 | 185 | }
|
| 186 | + .logo-width{ |
| 187 | + width:230px; |
| 188 | + } |
| 189 | + .logo-collapse-width{ |
| 190 | + width:60px |
| 191 | + } |
| 192 | + .tools{ |
| 193 | + padding: 0px 23px; |
| 194 | + width:14px; |
| 195 | + height: 60px; |
| 196 | + line-height: 60px; |
| 197 | + cursor: pointer; |
| 198 | + } |
147 | 199 | }
|
148 | 200 | .main {
|
| 201 | + display: flex; |
149 | 202 | // background: #324057;
|
150 | 203 | position: absolute;
|
151 | 204 | top: 60px;
|
152 | 205 | bottom: 0px;
|
153 | 206 | overflow: hidden;
|
154 | 207 | aside {
|
| 208 | + flex:0 0 230px; |
155 | 209 | width: 230px;
|
156 |
| - position: absolute; |
157 |
| - top: 0px; |
158 |
| - bottom: 0px; |
| 210 | + // position: absolute; |
| 211 | + // top: 0px; |
| 212 | + // bottom: 0px; |
159 | 213 | .el-menu{
|
160 | 214 | height: 100%;
|
161 | 215 | }
|
| 216 | + .collapsed{ |
| 217 | + width:60px; |
| 218 | + .item{ |
| 219 | + position: relative; |
| 220 | + } |
| 221 | + .submenu{ |
| 222 | + position:absolute; |
| 223 | + top:0px; |
| 224 | + left:60px; |
| 225 | + z-index:99999; |
| 226 | + height:auto; |
| 227 | + display:none; |
| 228 | + } |
| 229 | +
|
| 230 | + } |
| 231 | + } |
| 232 | + .menu-collapsed{ |
| 233 | + flex:0 0 60px; |
| 234 | + width: 60px; |
| 235 | + } |
| 236 | + .menu-expanded{ |
| 237 | + flex:0 0 230px; |
| 238 | + width: 230px; |
162 | 239 | }
|
163 | 240 | .content-container {
|
164 | 241 | // background: #f1f2f7;
|
165 |
| - position: absolute; |
166 |
| - right: 0px; |
167 |
| - top: 0px; |
168 |
| - bottom: 0px; |
169 |
| - left: 230px; |
| 242 | + flex:1; |
| 243 | + // position: absolute; |
| 244 | + // right: 0px; |
| 245 | + // top: 0px; |
| 246 | + // bottom: 0px; |
| 247 | + // left: 230px; |
170 | 248 | overflow-y: scroll;
|
171 | 249 | padding: 20px;
|
172 | 250 | .breadcrumb-container {
|
|
0 commit comments