Login.vue 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. <template>
  2. <div class="login login-box">
  3. <div class="login-body">
  4. <div class="login-title">
  5. <h1>逸教云</h1>
  6. </div>
  7. <div class="login-form">
  8. <el-form ref="loginForm" :model="loginModel" :rules="loginRules">
  9. <el-form-item prop="loginName">
  10. <el-input
  11. v-model.trim="loginModel.loginName"
  12. placeholder="请输入账号"
  13. clearable
  14. >
  15. <i class="icon icon-user" slot="prefix"></i>
  16. </el-input>
  17. </el-form-item>
  18. <el-form-item prop="password">
  19. <el-input
  20. type="password"
  21. v-model.trim="loginModel.password"
  22. placeholder="请输入密码"
  23. clearable
  24. >
  25. <i class="icon icon-lock" slot="prefix"></i
  26. ></el-input>
  27. </el-form-item>
  28. <el-form-item>
  29. <el-button
  30. style="width:116px;"
  31. type="primary"
  32. :disabled="isSubmit"
  33. @click="submit('loginForm')"
  34. >登录</el-button
  35. >
  36. </el-form-item>
  37. </el-form>
  38. </div>
  39. </div>
  40. <div class="login-shadow-top"></div>
  41. <div class="login-shadow-bottom"></div>
  42. </div>
  43. </template>
  44. <script>
  45. import { password } from "@/plugins/formRules";
  46. import { login } from "../api";
  47. export default {
  48. name: "login",
  49. data() {
  50. return {
  51. loginModel: {
  52. loginName: "",
  53. password: ""
  54. },
  55. loginRules: {
  56. loginName: [
  57. {
  58. required: true,
  59. message: "请输入用户名",
  60. trigger: "change"
  61. }
  62. ],
  63. password
  64. },
  65. roles: [],
  66. isSubmit: false
  67. };
  68. },
  69. mounted() {
  70. this.$ls.clear();
  71. },
  72. methods: {
  73. async submit(name) {
  74. const valid = await this.$refs[name].validate().catch(() => {});
  75. if (!valid) return;
  76. if (this.isSubmit) return;
  77. this.isSubmit = true;
  78. const data = await login(this.loginModel).catch(() => {});
  79. this.isSubmit = false;
  80. if (!data) return;
  81. this.$ls.set("token", data.token, this.GLOBAL.authTimeout);
  82. this.$ls.set("schoolId", data.account.schoolId, this.GLOBAL.authTimeout);
  83. this.$ls.set("user", data.account, this.GLOBAL.authTimeout);
  84. this.$store.commit("setUser", data.account);
  85. this.$router.push({
  86. name: "Home"
  87. });
  88. }
  89. }
  90. };
  91. </script>