本章只介紹基礎佈局,和一些主要的js,頁面上基本上都是些交互事件,項目代碼上都有註釋,不懂的地方debug跑一變就知道了,只是這些事件基本上沒有獨立存在的,相互之間都有關聯html
框架風格 vue
新建頁面:/src/views/layout/layout.vue
瀏覽器
<!-- layout.vue -->
<template>
<div id="loyout">
<el-container>
<layoutAside></layoutAside>
<el-container>
<layoutHeader></layoutHeader>
<el-main id="elmain">
<transition name="main" mode="out-in">
<router-view></router-view>
</transition>
</el-main>
<el-footer>
<Bottom></Bottom>
</el-footer>
</el-container>
</el-container>
</div>
</template>
複製代碼
新建頁面:/src/views/layout/aside/aside.vue
框架
<!-- aside.vue -->
<template>
<div>
<el-aside id="asideNav">
<div class="logo-name">
<p v-if="$store.getters.logoShow">XU</p>
<p v-else>vue-xuAdmin後臺模板</p>
</div>
<!-- el-menu的屬性查看官方文檔 -->
<el-menu :default-active="$route.path" class="el-menu-vertical" @select="selectmenu" :collapse="$store.getters.isCollapse" background-color="#03152A" text-color="rgba(255,255,255,.7)" active-text-color="#ffffff" :router="$store.getters.uniquerouter" :unique-opened="$store.getters.uniquerouter" :collapse-transition="true" >
<!-- 遍歷根據權限生成的路由表生成菜單列表 -->
<template v-for="(item,index) in $store.getters.routers" v-if="!item.hidden">
<!-- 檢查是否帶有alone屬性的一級菜單相似「主頁」,還有子菜單的個數 -->
<el-submenu v-if="!item.alone && item.children.length>0" :index="index+''">
<template slot="title">
<!-- 若是沒有設置圖標將會採用默認圖標‘fa fa-server’ -->
<i :class="item.iconCls?item.iconCls:[fa,fa-server]"></i>
<span slot="title">{{ $t(`routeNmae.${item.name}`) }}</span>
</template>
<!-- 子菜單組件 -->
<menu-tree :menuData="item.children"></menu-tree>
</el-submenu>
<!-- 一級菜單 -->
<el-menu-item :index="item.path" v-else>
<i :class="item.iconCls?item.iconCls:[fa,fa-file]"></i>
<span slot="title">{{ $t(`routeNmae.${item.name}`) }}</span>
</el-menu-item>
</template>
</el-menu>
</el-aside>
</div>
</template>
複製代碼
點擊菜單ide
// aside.vue
watch: {
// 監聽瀏覽器直接輸入路由,將此路由添加到tabnavBox
'$route.path': function (val) {
this.selectmenu(val)
}
},
// 點擊菜單把當前菜單的name和path添加到tabNavBox容器,生成tabNav標籤頁菜單
selectmenu (key) {
// 獲取當前權限路由表
let router = this.$store.getters.routers
let name = ''
// 查找路由的name屬性
let navTitle = function (path, routerARR) {
for (let i = 0; i < routerARR.length; i++) {
if (routerARR[i].children.length > 0 || routerARR[i].path === path) {
if (routerARR[i].path === path && routerARR[i].children.length < 1) {
name = routerARR[i].name
break
}
// 遞歸查找
navTitle(path, routerARR[i].children)
}
}
return name
}
// tabNavBox添加數據
this.$store.dispatch('addTab', {
title: navTitle(key, router),
path: key
})
}
複製代碼
子菜單組件 menu-true
佈局
新建頁面:/src/views/layout/aside/menuTree.vue
post
<!-- menuTree.vue -->
<template>
<div>
<template v-for="(child,index) in menuData">
<el-submenu v-if="child.children.length > 0" :index="child.path">
<template slot="title">
<i :class="child.iconCls?child.iconCls:[fa,fa-file]"></i>
<span slot="title">{{ $t(`routeNmae.${child.name}`) }}</span>
</template>
<!-- 經過遞歸 menu-tree 生成無限級菜單 -->
<menu-tree :menuData="child.children"></menu-tree>
</el-submenu>
<el-menu-item v-else :index="child.path">
<i :class="child.iconCls?child.iconCls:[fa,fa-file]"></i>
<span slot="title">{{ $t(`routeNmae.${child.name}`) }}</span>
</el-menu-item>
</template>
</div>
</template>
複製代碼
這裏沒啥好說的,都是html佈局,tabnav接下來講, i18n後面會講動畫
新建頁面:/src/views/layout/header/header.vue
this
<!-- header.vue -->
<template>
<div>
<el-header id="header">
<span class="hideAside" @click="collapse"><i class="fa fa-indent fa-lg"></i></span>
<ul class="personal">
<li class="fullScreen" @click="fullScreen">
<el-tooltip class="item" effect="dark" content="全屏" placement="bottom"><i class="fa fa-arrows-alt fa-lg"></i></el-tooltip>
</li>
<li>
<langSelect></langSelect>
</li>
<li>{{ $t(`role.${this.$store.getters.info.role}`) }}</li>
<li>
<el-dropdown @command="handleCommand">
<span class="el-dropdown-link">
夏洛克丶旭<i class="el-icon-arrow-down el-icon--right"></i>
</span>
<el-dropdown-menu slot="dropdown">
<el-dropdown-item command="a">{{ $t('userDropdownMenu.basicInfor') }}</el-dropdown-item>
<el-dropdown-item command="b">{{ $t('userDropdownMenu.changePassword') }}</el-dropdown-item>
<el-dropdown-item command="logout" divided>{{ $t('userDropdownMenu.logout') }}</el-dropdown-item>
</el-dropdown-menu>
</el-dropdown>
</li>
<li class="icon"><img :src="avatar"/></li>
</ul>
</el-header>
<!-- tabNav 組件,標籤頁菜單 -->
<tabNav></tabNav>
</div>
</template>
複製代碼
這裏的tabNav標籤動畫和頁面的動畫是同樣的,都是官方的demo稍微改一下,,只不過頁面有mode="out-in"
因此動畫時間須要快一點spa
新建頁面:/src/views/layout/header/tabNav.vue
<!-- tabNav.vue -->
<template>
<div>
<div class="tabnavBox">
<transition-group name="list" tag="ul">
<!-- tabnavBox 是存儲全部tabNav的數據容器,每次點擊左側菜單就會把數據添加到tabnavBox -->
<li v-for="(item, index) in $store.getters.tabnavBox" @contextmenu.prevent="openMenu(item,$event,index)" :key="item.title" class="tabnav" :class="{ active: $route.path === item.path }">
<router-link :to="item.path">{{ $t(`routeNmae.${item.title}`) }}</router-link>
<i @click="removeTab(item)" class="el-icon-error" v-if="index !== 0"></i>
</li>
</transition-group>
</div>
<!-- 右擊菜單 -->
<ul v-show="this.rightMenuShow" :style="{left:this.left+'px',top:this.top+'px'}" class="menuBox">
<li @click="removeTab($store.getters.rightNav)"><i class="fa fa-remove"></i>{{ $t('rightMenu.close') }}</li>
<li @click="removeOtherTab($store.getters.rightNav)">{{ $t('rightMenu.closeOther') }}</li>
<li @click="removeAllTab">{{ $t('rightMenu.closeAll') }}</li>
</ul>
</div>
</template>
複製代碼
Vue2.0 + ElementUI 手寫權限管理系統後臺模板(一)——簡述
Vue2.0 + ElementUI 手寫權限管理系統後臺模板(二)——權限管理