Browse Source

自动路由

scorpio 2 years ago
parent
commit
7cffa5dad0
9 changed files with 190 additions and 28 deletions
  1. 4 4
      index.html
  2. BIN
      src/assets/img/logo.png
  3. 1 0
      src/assets/style/main.scss
  4. 7 5
      src/layout/index.vue
  5. 1 1
      src/layout/letf.vue
  6. 21 16
      src/layout/top.vue
  7. 1 1
      src/main.js
  8. 154 0
      src/page/login.vue
  9. 1 1
      src/router/index.js

+ 4 - 4
index.html

@@ -1,13 +1,13 @@
 <!DOCTYPE html>
-<html lang="en">
+<html lang="en" style='height: 100%'>
   <head>
     <meta charset="UTF-8" />
     <link rel="icon" type="image/svg+xml" href="/vite.svg" />
     <meta name="viewport" content="width=device-width, initial-scale=1.0" />
-    <title>Vite + Vue</title>
+    <title>梧桐树项目管理平台</title>
   </head>
-  <body>
-    <div id="app"></div>
+  <body style='height: 100%'>
+    <div id="app" style='height: 100%'></div>
     <script type="module" src="/src/main.js">
       console.info('%c由%cFantastic-admin%c提供支持', 'font-size: 14px; margin-bottom: 2px; padding: 6px 8px; color: #fff; background: #707070;', 'font-size: 14px; margin-bottom: 2px; padding: 6px 8px; color: #fff; background: #e24329;', 'font-size: 14px; margin-bottom: 2px; padding: 6px 8px; color: #fff; background: #707070;', '\nhttps://gitee.com/hooray/fantastic-admin')
     </script>

BIN
src/assets/img/logo.png


+ 1 - 0
src/assets/style/main.scss

@@ -123,6 +123,7 @@ img {vertical-align: top;}
 .ml-20 { margin-left: 20px; }
 .padding { padding: 10px; }
 .padding-14 { padding: 14px; }
+.padding-20 { padding: 20px; }
 .padding-top { padding-top: 10px; }
 .padding-right { padding-right: 10px; }
 .padding-bottom { padding-bottom: 10px; }

+ 7 - 5
src/layout/index.vue

@@ -1,11 +1,11 @@
 <template>
   <div class='full-screen flex flex-justify-start'>
-    <el-aside width="200px" >
+    <el-aside width="300px" >
       <left/>
     </el-aside>
     <el-container>
-      <el-header style='padding: 0' class='light-green-bg full-width'>
-          <top class='full-width'/>
+      <el-header class='header'>
+          <top />
       </el-header>
       <el-main>
         <el-card >
@@ -28,6 +28,8 @@ export default {
 }
 </script>
 
-<style lang='menu' scoped>
-
+<style lang='scss' scoped>
+.header{
+  padding: 0;
+}
 </style>

+ 1 - 1
src/layout/letf.vue

@@ -47,7 +47,7 @@ export default {
 <style scoped>
 .box-shadow-blue {
   position: fixed;
-  width: 200px;
+  width: 300px;
   left: 0;
   z-index: 2;
   background-color: white;

+ 21 - 16
src/layout/top.vue

@@ -1,19 +1,23 @@
 <template>
-      <div class='flex flex-align-center flex-justify-between top flex-child-grow'>
-        <div class='flex flex-justify-start flex-child-average  padding-left padding-right '>
-          <el-icon :size="20">
-            <Filter />
-          </el-icon>
-          <el-breadcrumb class='ml-20' separator="/">
-            <el-breadcrumb-item v-for='item in nav.menus' :key='item.id'>
-              <a :href="item.path">{{ item.name }}</a>
-            </el-breadcrumb-item>
-          </el-breadcrumb>
-        </div>
-        <div class='flex-child-average flex-justify-end flex padding-right  '>
-          <el-button @click='nav.cleanMenu()'>清除缓存</el-button>
-        </div>
-      </div>
+      <el-row class='flex flex-align-center flex-justify-between top '>
+        <el-col  :span='12'>
+          <div class='flex flex-justify-start flex-align-center light-green-bg'>
+            <el-icon :size="20">
+              <Filter />
+            </el-icon>
+            <el-breadcrumb class='ml-20' separator="/">
+              <el-breadcrumb-item v-for='item in nav.menus' :key='item.id'>
+                <a :href="item.path">{{ item.name }}</a>
+              </el-breadcrumb-item>
+            </el-breadcrumb>
+          </div>
+        </el-col>
+        <el-col :span='12'>
+          <div class='flex-child-average flex-justify-center flex padding-right  light-green-bg'>
+            <el-button @click='nav.cleanMenu()'>清除缓存</el-button>
+          </div>
+        </el-col>
+      </el-row>
 </template>
 
 <script>
@@ -35,11 +39,12 @@ export default {
 
 <style lang='scss' scoped>
 .top{
-  width: 92.5%;
   height: 60px;
   z-index: 1;
   background-color: white;
   top: 0;
+  left: 300px;
+  right: 0;
   position: fixed;
   border-bottom: whitesmoke solid 1px;
   box-shadow: 0 5px 10px -5px rgba(0, 0, 0, 0.1);

+ 1 - 1
src/main.js

@@ -27,5 +27,5 @@ for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
 myApp
   .use(pinia)
   .use(router)
-  .use(elementPlus, { size: 'small', zIndex: 300 })
+  .use(elementPlus, { size: 'default', zIndex: 300 })
   .mount('#app')

+ 154 - 0
src/page/login.vue

@@ -0,0 +1,154 @@
+<template>
+  <div class='full-screen flex flex-center '>
+    <el-card class='login'>
+      <div class='flex flex-center' style='width: 100%'>
+        <div class='flex-child-average  flex flex-center left'>
+          <div class='flex flex-justify-start flex-align-start full-height '>
+            <img src='@/assets/img/logo.png' class='padding-14 logo'/>
+            <img src='https://hooray.gitee.io/fantastic-admin-example/assets/login-banner.a565fac8.png' class='logo-main' />
+          </div>
+        </div>
+
+        <div class='flex-child-average right'>
+          <div class='padding-20'>
+            <span class='font-24 black bold '>欢迎来到梧桐树云项目管理云平台👏</span>
+            <el-form class='form' :model="form" :rules="rules" ref='loginForm'>
+              <el-form-item prop='name'>
+                <el-input
+                  v-model='form.name'
+                  size='large'
+                  placeholder="用户名"
+                  prefix-icon="Avatar"
+                />
+              </el-form-item>
+              <el-form-item prop='pass'>
+                <el-input
+                  v-model='form.pass'
+                  size='large'
+                  placeholder="密码"
+                  :type='flag ? "text" : "password"'
+                  prefix-icon="WalletFilled">
+                    <template   v-slot:suffix>
+                      <div @click='flag=!flag' class='pointer'>
+                        <el-icon v-if='!flag'><Hide /></el-icon>
+                        <el-icon v-else><View /></el-icon>
+                      </div>
+                    </template>
+                </el-input>
+              </el-form-item>
+              <el-form-item>
+                <div class='flex flex-align-center flex-justify-between full-width'>
+                  <el-checkbox :checked='true'>记住我</el-checkbox>
+                  <el-button type='text' class='font-12'>忘记密码?</el-button>
+                </div>
+              </el-form-item>
+            </el-form>
+            <el-button type='primary' class='full-width' size='large' @click='submint'>登录</el-button>
+            <div class='mt-20 flex flex-center'>
+              <span>还没账户?</span>
+              <el-button type='text'>注册账户</el-button>
+            </div>
+            <el-divider/>
+            <div class='flex flex-col'>
+              <span class='grey-6'>
+              由梧桐经济学院提供技术支持
+              </span>
+              <div>
+                <el-button size='small' type='primary' plain class='mt-10' @click='loginAdmin'>admin</el-button>
+              </div>
+            </div>
+          </div>
+        </div>
+      </div>
+    </el-card>
+  </div>
+</template>
+
+<route>
+  {
+    meta: {
+    layout: 'empty',
+    },
+  }
+</route>
+
+<script>
+export default {
+  name: 'login',
+  data () {
+    return {
+      flag: false,
+      form: {
+        name: '',
+        pass: ''
+      },
+      rules: {
+        name: [
+          { required: true, message: '请输入用户名', trigger: 'blur' },
+          { min: 3, max: 12, message: '长度在 3 到 12 个字符', trigger: 'blur' }
+        ],
+        pass: [
+          { required: true, message: '请输入密码', trigger: 'blur' },
+          { min: 3, max: 12, message: '长度在 3 到 12 个字符', trigger: 'blur' }
+        ]
+      }
+    }
+  },
+  methods: {
+    submint () {
+      this.$refs.loginForm.validate((res) => {
+        if (res) {
+          this.$message.success('登录成功')
+          this.$router.replace('/')
+        } else {
+          this.$message.error('登录失败')
+          return false
+        }
+      })
+    },
+    loginAdmin () {
+      this.form.name = 'admin'
+      this.form.pass = 'admin'
+      this.submint()
+    }
+  }
+}
+</script>
+
+<style lang='scss' scoped>
+.login{
+  :deep(.el-card__body){
+    padding: 0 !important;
+  };
+  padding: 0;
+  display: flex;
+  top: 50%;
+  left: 50%;
+  border-radius: 10px;
+  background-color: white;
+  width: 950px;
+  height: 500px;
+  .left {
+    background-color: #F5F7FA;
+    height: 500px;
+    .logo {
+      width: 45px;
+      height: 45px;
+      border-radius: 50%;
+    }
+    .logo-main {
+      width: 100%;
+      margin-top: 70px;
+      margin-left: -80px;
+    }
+  }
+  .right {
+    background-color: white;
+    height: 500px;
+    .form{
+      margin-top: 40px;
+    }
+  }
+
+}
+</style>

+ 1 - 1
src/router/index.js

@@ -12,7 +12,7 @@ const router = createRouter({
 })
 
 router.beforeEach((to, from, next) => {
-  console.log(generatedRoutes)
+  // console.log(generatedRoutes)
   const nav = navStore()
   nav.updateMenu(to)
   if (to.matched.length) {