fix:路由处理,CSS处理,样式处理,全局变量处理

This commit is contained in:
MTrun
2021-12-14 15:53:30 +08:00
parent e09ad35a4a
commit 7e5d5aa067
32 changed files with 1837 additions and 257 deletions
+26 -23
View File
@@ -1,40 +1,43 @@
<template>
<div class="flex flex-col justify-center page-container">
<div class="go-error">
<div class="text-center">
<img src="~@/assets/images/exception/404.svg" alt="" />
</div>
<div class="text-center">
<h1 class="text-base text-gray-500">抱歉你访问的页面不存在</h1>
<n-button type="info" @click="goHome">回到首页</n-button>
</div>
<n-button type="info" @click="goHome">回到首页</n-button>
</div>
</template>
<script lang="ts" setup>
import { useRouter } from 'vue-router';
const router = useRouter();
function goHome() {
router.push('/');
}
import { useRouter } from 'vue-router'
import { PageEnum } from '@/enums/pageEnum'
const router = useRouter()
function goHome() {
router.push({
name: PageEnum.BASE_HOME_NAME
})
}
</script>
<style lang="scss" scoped>
.page-container {
width: 100%;
border-radius: 4px;
padding: 50px 0;
height: 100vh;
.text-center {
h1 {
color: #666;
padding: 20px 0;
}
}
img {
width: 350px;
margin: 0 auto;
@include go(error) {
display: flex;
flex-direction: column;
align-items: center;
width: 100%;
padding: 100px 0;
.text-center {
h1 {
color: #666;
padding: 20px 0;
}
}
img {
width: 350px;
margin: 0 auto;
}
}
</style>
+96 -95
View File
@@ -1,68 +1,70 @@
<template>
<div class="view-account">
<div class="view-account-header"></div>
<div class="view-account-container">
<div class="view-account-top">
<div class="view-account-top-logo">
<img src="~@/assets/images/logo.png" alt="" />
<div class="go-login">
<div class="login-account">
<div class="login-account-header"></div>
<div class="login-account-container">
<div class="login-account-top">
<div class="login-account-top-logo">
<img src="~@/assets/images/logo.png" alt="" />
</div>
<div class="login-account-top-desc">
GoView
</div>
</div>
<div class="view-account-top-desc">
GoView
</div>
</div>
<div class="view-account-form">
<n-form
ref="formRef"
label-placement="left"
size="large"
:model="formInline"
:rules="rules"
>
<n-form-item path="username">
<n-input
v-model:value="formInline.username"
placeholder="请输入用户名"
>
<template #prefix>
<n-icon size="18" color="#808695">
<PersonOutline />
</n-icon>
</template>
</n-input>
</n-form-item>
<n-form-item path="password">
<n-input
v-model:value="formInline.password"
type="password"
show-password-toggle
placeholder="请输入密码"
>
<template #prefix>
<n-icon size="18" color="#808695">
<LockClosedOutline />
</n-icon>
</template>
</n-input>
</n-form-item>
<n-form-item class="default-color">
<div class="flex justify-between">
<div class="flex-initial">
<n-checkbox v-model:checked="autoLogin">自动登录</n-checkbox>
<div class="login-account-form">
<n-form
ref="formRef"
label-placement="left"
size="large"
:model="formInline"
:rules="rules"
>
<n-form-item path="username">
<n-input
v-model:value="formInline.username"
placeholder="请输入用户名"
>
<template #prefix>
<n-icon size="18" color="#808695">
<PersonOutline />
</n-icon>
</template>
</n-input>
</n-form-item>
<n-form-item path="password">
<n-input
v-model:value="formInline.password"
type="password"
show-password-toggle
placeholder="请输入密码"
>
<template #prefix>
<n-icon size="18" color="#808695">
<LockClosedOutline />
</n-icon>
</template>
</n-input>
</n-form-item>
<n-form-item class="default-color">
<div class="flex justify-between">
<div class="flex-initial">
<n-checkbox v-model:checked="autoLogin">自动登录</n-checkbox>
</div>
</div>
</div>
</n-form-item>
<n-form-item>
<n-button
type="primary"
@click="handleSubmit"
size="large"
:loading="loading"
block
>
登录
</n-button>
</n-form-item>
</n-form>
</n-form-item>
<n-form-item>
<n-button
type="primary"
@click="handleSubmit"
size="large"
:loading="loading"
block
>
登录
</n-button>
</n-form-item>
</n-form>
</div>
</div>
</div>
</div>
@@ -72,10 +74,7 @@
import { reactive, ref } from 'vue'
import { useRoute, useRouter } from 'vue-router'
import { useMessage } from 'naive-ui'
import {
PersonOutline,
LockClosedOutline,
} from '@vicons/ionicons5'
import { PersonOutline, LockClosedOutline } from '@vicons/ionicons5'
interface FormState {
username: string
@@ -117,46 +116,48 @@ const handleSubmit = (e: Event) => {
</script>
<style lang="scss" scoped>
.view-account {
display: flex;
flex-direction: column;
height: 100vh;
overflow: auto;
background-image: linear-gradient(to top, #fff1eb 0%, #ace0f9 100%);
@include go(login) {
.login-account {
display: flex;
flex-direction: column;
height: 100vh;
overflow: auto;
background-image: linear-gradient(to top, #fff1eb 0%, #ace0f9 100%);
&-container {
flex: 1;
padding: 32px 0;
width: 384px;
margin: 0 auto;
margin-top: 100px;
}
&-top {
padding: 32px 0;
text-align: center;
&-desc {
font-size: 14px;
color: #808695;
&-container {
flex: 1;
padding: 32px 0;
width: 384px;
margin: 0 auto;
margin-top: 100px;
}
}
&-other {
width: 100%;
}
&-top {
padding: 32px 0;
text-align: center;
.default-color {
color: #515a6e;
&-desc {
font-size: 14px;
color: #808695;
}
}
.ant-checkbox-wrapper {
&-other {
width: 100%;
}
.default-color {
color: #515a6e;
.ant-checkbox-wrapper {
color: #515a6e;
}
}
}
}
@media (min-width: 768px) {
.view-account {
.login-account {
background-repeat: no-repeat;
background-position: 50%;
background-size: 100%;