'admin-21.01.05:编写布局配置相对应功能、添加过渡动画等'

This commit is contained in:
lyt-Top 2021-01-05 23:58:16 +08:00
parent c0a369c6d0
commit 4a916d6d12
11 changed files with 107 additions and 31 deletions

View File

@ -6,7 +6,7 @@
"build": "vite build"
},
"dependencies": {
"element-plus": "^v1.0.1-beta.19",
"element-plus": "^v1.0.1-beta.20",
"mitt": "^2.1.0",
"sortablejs": "^1.10.2",
"vue": "^3.0.5",

View File

@ -0,0 +1,9 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 47 35" width="47" height="35">
<defs>
<image width="41" height="29" id="img1" href=""/>
</defs>
<style>
tspan { white-space:pre }
</style>
<use id="图层 1" href="#img1" x="3" y="3" />
</svg>

After

Width:  |  Height:  |  Size: 2.9 KiB

View File

@ -20,7 +20,8 @@ export interface RootStateTypes {
isUniqueOpened: boolean,
isFixedHeader: boolean,
isCollapse1: boolean,
menuWidth: number,
menuWidth1: number,
isShowLogo: boolean
}
}

View File

@ -34,6 +34,8 @@ body,
height: inherit;
position: relative;
z-index: 1;
display: flex;
flex-direction: column;
}
.el-header {
box-shadow: 0 1px 4px rgb(0 21 41 / 8%);
@ -51,7 +53,7 @@ body,
.el-scrollbar {
width: 100%;
}
.layout-aside-width240 {
.layout-aside-width-default {
width: 240px !important;
transition: width 0.3s ease;
}
@ -85,6 +87,15 @@ body,
}
}
/* flex 弹性布局
------------------------------- */
.flex {
display: flex;
}
.flex-auto {
flex: 1;
}
/* 宽高 100%
------------------------------- */
.w100 {

View File

@ -35,3 +35,17 @@
opacity: 0;
transform: translateX(20px);
}
/* logo 过渡动画
------------------------------- */
@keyframes logoAnimation {
0% {
transform: scale(0);
}
80% {
transform: scale(1.2);
}
100% {
transform: scale(1);
}
}

View File

@ -17,5 +17,6 @@ export default {
isUniqueOpened: false,
isFixedHeader: false,
isCollapse1: false,
menuWidth: 240,
menuWidth1: 200,
isShowLogo: false
}

View File

@ -1,19 +1,22 @@
<template>
<el-aside :class="isCollapse ? 'layout-aside-width64' : 'layout-aside-width240'">
<el-scrollbar>
<el-aside :class="getThemeConfig.isCollapse ? 'layout-aside-width64' : 'layout-aside-width-default'">
<Logo v-if="getThemeConfig.isShowLogo" />
<el-scrollbar class="flex-auto" ref="layoutAsideScrollbarRef">
<Vertical :menuList="menuList" />
</el-scrollbar>
</el-aside>
</template>
<script lang="ts">
import Logo from "/@/views/layout/logo/index.vue";
import Vertical from "/@/views/layout/navMenu/vertical.vue";
import { toRefs, reactive, computed } from "vue";
import { toRefs, reactive, computed, watch, getCurrentInstance } from "vue";
import { useStore } from "/@/store/index.ts";
export default {
name: "layoutAside",
components: { Vertical },
components: { Logo, Vertical },
setup() {
const { proxy } = getCurrentInstance();
const store = useStore();
const state = reactive({
menuList: [
@ -64,11 +67,14 @@ export default {
},
],
});
const isCollapse = computed(() => {
return store.state.themeConfig.isCollapse;
const getThemeConfig = computed(() => {
return store.state.themeConfig;
});
watch(store.state.themeConfig, (val) => {
proxy.$refs.layoutAsideScrollbarRef.update();
});
return {
isCollapse,
getThemeConfig,
...toRefs(state),
};
},

View File

@ -1,6 +1,5 @@
<template>
<el-main :class="getThemeConfig.isFixedHeader ? 'el-main-overflow-auto' : 'el-main-overflow-unset'">
<!-- <el-main> -->
<el-scrollbar class="layout-scrollbar" style="min-height: calc(100vh - 84px);" ref="layoutScrollbarRef">
<router-view v-slot="{ Component }">
<transition :name="transitionName" mode="out-in">

View File

@ -1,9 +1,46 @@
<template>
layoutLogo
<div class="layout-logo" v-if="!getThemeConfig.isCollapse">vue-admin-wonderful</div>
<div class="layout-logo-size" v-else>
<img src="/@/assets/logo-docs-mini.svg" class="layout-logo-size-img" />
</div>
</template>
<script lang="ts">
import { computed } from "vue";
import { useStore } from "/@/store/index.ts";
export default {
name: "layoutLogo",
setup() {
const store = useStore();
const getThemeConfig = computed(() => {
return store.state.themeConfig;
});
return {
getThemeConfig,
};
},
};
</script>
</script>
<style scoped lang="scss">
.layout-logo {
height: 50px;
display: flex;
align-items: center;
justify-content: center;
box-shadow: rgb(0 21 41 / 2%) 0px 1px 4px;
color: var(--color-primary);
font-size: 16px;
animation: logoAnimation 0.3s ease-in-out;
}
.layout-logo-size {
width: 100%;
height: 50px;
display: flex;
animation: logoAnimation 0.3s ease-in-out;
&-img {
width: 30px;
margin: auto;
}
}
</style>

View File

@ -115,18 +115,10 @@
<el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
</div>
</div>
<div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">菜单展开宽度</div>
<div class="layout-breadcrumb-seting-bar-flex-value">
<el-input-number v-model="getThemeConfig.menuWidth" controls-position="right" :min="1" :max="999"
size="mini" style="width:90px;">
</el-input-number>
</div>
</div>
<div class="layout-breadcrumb-seting-bar-flex mt11">
<div class="layout-breadcrumb-seting-bar-flex-label">自动锁屏</div>
<div class="layout-breadcrumb-seting-bar-flex-value">
<el-input-number v-model="getThemeConfig.menuWidth" controls-position="right" :min="1" :max="999"
<el-input-number v-model="getThemeConfig.menuWidth1" controls-position="right" :min="1" :max="999"
size="mini" style="width:90px;">
</el-input-number>
</div>
@ -137,7 +129,7 @@
<div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">侧边栏 Logo</div>
<div class="layout-breadcrumb-seting-bar-flex-value">
<el-switch v-model="getThemeConfig.isCollapse1"></el-switch>
<el-switch v-model="getThemeConfig.isShowLogo" @change="onsetThemeConfigChange"></el-switch>
</div>
</div>
<div class="layout-breadcrumb-seting-bar-flex mt15">
@ -179,7 +171,7 @@
<div class="layout-breadcrumb-seting-bar-flex mt15">
<div class="layout-breadcrumb-seting-bar-flex-label">水印文案</div>
<div class="layout-breadcrumb-seting-bar-flex-value">
<el-input v-model="getThemeConfig.menuWidth" size="mini" style="width:90px;"></el-input>
<el-input v-model="getThemeConfig.menuWidth1" size="mini" style="width:90px;"></el-input>
</div>
</div>

View File

@ -1,9 +1,13 @@
<template>
<div class="layout-navbars-breadcrumb-user">
<i class="el-icon-search layout-navbars-breadcrumb-user-icon" title="菜单搜索"></i>
<i class="el-icon-setting layout-navbars-breadcrumb-user-icon" title="布局配置" @click="onLayoutSetingClick"></i>
<i class="el-icon-bell layout-navbars-breadcrumb-user-icon" title="消息"></i>
<i class="icon-fullscreen iconfont layout-navbars-breadcrumb-user-icon mr10" title="开全屏"></i>
<div class="layout-navbars-breadcrumb-user-icon">
<i class="el-icon-search" title="菜单搜索"></i>
</div>
<div class="layout-navbars-breadcrumb-user-icon" @click="onLayoutSetingClick">
<i class="el-icon-setting" title="布局配置"></i>
</div>
<div class="layout-navbars-breadcrumb-user-icon"><i class="el-icon-bell" title="消息"></i></div>
<div class="layout-navbars-breadcrumb-user-icon mr10"><i class="icon-fullscreen iconfont" title="开全屏"></i></div>
<el-dropdown :show-timeout="70" :hide-timeout="50">
<span class="layout-navbars-breadcrumb-user-link">
<img src="https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=1813762643,1914315241&fm=26&gp=0.jpg"
@ -59,15 +63,17 @@ export default {
}
}
&-icon {
display: inline-block;
padding: 0 10px;
cursor: pointer;
transition: all 0.3s;
color: var(--bg-topBarColor);
height: 50px;
line-height: 50px;
&:hover {
background: rgba(0, 0, 0, 0.04);
i {
display: inline-block;
animation: logoAnimation 0.3s ease-in-out;
}
}
}
::v-deep(.el-dropdown) {