Files
nexusphp/admin/src/App.vue
T

213 lines
5.9 KiB
Vue
Raw Normal View History

2021-03-31 19:39:59 +08:00
<template>
2021-04-12 20:31:02 +08:00
<div class="layout">
<el-container v-if="state.showMenu" class="container">
<el-aside class="aside">
<div class="head">
2021-04-02 19:48:41 +08:00
<div>
2021-04-12 20:31:02 +08:00
<img src="https://s.weituibao.com/1582958061265/mlogo.png" alt="logo">
<span>vue3 admin</span>
2021-04-02 19:48:41 +08:00
</div>
</div>
2021-04-12 20:31:02 +08:00
<div class="line" />
2021-04-02 19:48:41 +08:00
<el-menu
2021-04-12 20:31:02 +08:00
:default-openeds="state.defaultOpen"
background-color="#222832"
text-color="#fff"
:router="true"
:default-active='state.currentPath'
>
2021-04-02 19:48:41 +08:00
<el-submenu index="1">
<template #title>
2021-04-12 20:31:02 +08:00
<span>Dashboard</span>
2021-04-02 19:48:41 +08:00
</template>
<el-menu-item-group>
2021-04-12 20:31:02 +08:00
<el-menu-item index="/introduce"><i class="el-icon-data-line" />系统介绍</el-menu-item>
<el-menu-item index="/dashboard"><i class="el-icon-odometer" />Dashboard</el-menu-item>
<el-menu-item index="/add"><i class="el-icon-plus" />添加商品</el-menu-item>
2021-04-02 19:48:41 +08:00
</el-menu-item-group>
2021-04-12 20:31:02 +08:00
</el-submenu>
<el-submenu index="2">
<template #title>
<span>首页配置</span>
</template>
<el-menu-item-group>
<el-menu-item index="/swiper"><i class="el-icon-picture" />轮播图配置</el-menu-item>
2021-04-15 19:20:32 +08:00
<el-menu-item index="/agent-allow"><i class="el-icon-picture" />允许客户端</el-menu-item>
2021-04-17 19:01:33 +08:00
<el-menu-item index="/user"><i class="el-icon-user" />用户</el-menu-item>
2021-04-19 20:13:21 +08:00
<el-menu-item index="/exam"><i class="el-icon-s-check" />考核</el-menu-item>
2021-04-12 20:31:02 +08:00
<el-menu-item index="/hot"><i class="el-icon-star-on" />热销商品配置</el-menu-item>
<el-menu-item index="/new"><i class="el-icon-sell" />新品上线配置</el-menu-item>
<el-menu-item index="/recommend"><i class="el-icon-thumb" />为你推荐配置</el-menu-item>
2021-04-02 19:48:41 +08:00
</el-menu-item-group>
</el-submenu>
2021-04-12 20:31:02 +08:00
<el-submenu index="3">
2021-04-02 19:48:41 +08:00
<template #title>
2021-04-12 20:31:02 +08:00
<span>模块管理</span>
2021-04-02 19:48:41 +08:00
</template>
<el-menu-item-group>
2021-04-12 20:31:02 +08:00
<el-menu-item index="/category"><i class="el-icon-menu" />分类管理</el-menu-item>
<el-menu-item index="/good"><i class="el-icon-s-goods" />商品管理</el-menu-item>
<el-menu-item index="/guest"><i class="el-icon-user-solid" />会员管理</el-menu-item>
<el-menu-item index="/order"><i class="el-icon-s-order" />订单管理</el-menu-item>
2021-04-02 19:48:41 +08:00
</el-menu-item-group>
2021-04-12 20:31:02 +08:00
</el-submenu>
<el-submenu index="4">
<template #title>
<span>系统管理</span>
</template>
<el-menu-item-group>
<el-menu-item index="/account"><i class="el-icon-lock" />修改密码</el-menu-item>
<!-- <el-menu-item><i class="el-icon-upload2" />安全退出</el-menu-item> -->
2021-04-02 19:48:41 +08:00
</el-menu-item-group>
2021-04-01 19:50:41 +08:00
</el-submenu>
2021-04-02 19:48:41 +08:00
</el-menu>
</el-aside>
2021-04-12 20:31:02 +08:00
<el-container class="content">
<Header />
<div class="main">
<router-view />
</div>
<Footer />
2021-04-02 19:48:41 +08:00
</el-container>
</el-container>
2021-04-12 20:31:02 +08:00
<el-container v-else class="container">
<router-view />
</el-container>
</div>
2021-03-31 19:39:59 +08:00
</template>
<script>
2021-04-12 20:31:02 +08:00
import { reactive } from 'vue'
import Header from '@/components/Header.vue'
import Footer from '@/components/Footer.vue'
import { useRouter } from 'vue-router'
import { pathMap, localGet } from '@/utils'
2021-03-31 19:39:59 +08:00
export default {
2021-04-12 20:31:02 +08:00
name: 'App',
components: {
Header,
Footer
2021-04-01 19:50:41 +08:00
},
2021-04-12 20:31:02 +08:00
setup() {
const noMenu = ['/login']
const router = useRouter()
const state = reactive({
defaultOpen: ['1', '2', '3', '4'],
showMenu: true,
currentPath: '/dashboard',
count: {
number: 1
}
})
router.beforeEach((to, from, next) => {
if (to.path == '/login') {
// 如果路径是 /login 则正常执行
next()
} else {
// 如果不是 /login,判断是否有 token
if (!localGet('token')) {
// 如果没有,则跳至登录页面
next({ path: '/login' })
} else {
// 否则继续执行
next()
}
}
state.showMenu = !noMenu.includes(to.path)
state.currentPath = to.path
document.title = pathMap[to.name]
})
return {
state
2021-04-01 19:50:41 +08:00
}
2021-03-31 19:39:59 +08:00
}
}
</script>
2021-04-12 20:31:02 +08:00
<style scoped>
.layout {
min-height: 100vh;
background-color: #ffffff;
}
.container {
height: 100vh;
}
.aside {
width: 200px!important;
background-color: #222832;
overflow: hidden;
overflow-y: auto;
-ms-overflow-style: none;
overflow: -moz-scrollbars-none;
2021-04-02 19:48:41 +08:00
}
2021-04-12 20:31:02 +08:00
.aside::-webkit-scrollbar {
display: none;
}
.head {
2021-04-02 19:48:41 +08:00
display: flex;
2021-04-12 20:31:02 +08:00
align-items: center;
2021-04-02 19:48:41 +08:00
justify-content: center;
2021-04-12 20:31:02 +08:00
height: 50px;
2021-04-02 19:48:41 +08:00
}
2021-04-12 20:31:02 +08:00
.head > div {
2021-04-02 19:48:41 +08:00
display: flex;
align-items: center;
}
2021-04-12 20:31:02 +08:00
.head img {
width: 50px;
height: 50px;
margin-right: 10px;
}
.head span {
font-size: 20px;
color: #ffffff;
}
.line {
border-top: 1px solid hsla(0,0%,100%,.05);
border-bottom: 1px solid rgba(0,0,0,.2);
}
.content {
display: flex;
flex-direction: column;
max-height: 100vh;
overflow: hidden;
}
.main {
height: calc(100vh - 100px);
overflow: auto;
padding: 10px;
}
</style>
<style>
body {
padding: 0;
margin: 0;
box-sizing: border-box;
}
.el-menu {
border-right: none!important;
}
.el-submenu {
border-top: 1px solid hsla(0, 0%, 100%, .05);
border-bottom: 1px solid rgba(0, 0, 0, .2);
}
.el-submenu:first-child {
border-top: none;
}
.el-submenu [class^="el-icon-"] {
vertical-align: -1px!important;
}
a {
color: #409eff;
text-decoration: none;
}
.el-pagination {
text-align: center;
margin-top: 20px;
}
.el-popper__arrow {
display: none;
}
2021-03-31 19:39:59 +08:00
</style>