123
gaoshp
刚刚 4c2a27b9d7604287c4f94c88a84a1f10a44ad39c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
<template>
  <div class="mac_bg"></div>
  <div class="login animate__animated" :class="{ animate__bounceOut: pass }">
    <div class="head">
      <img
        src="https://bladex.cn/images/logo-small.png"
        alt=""
      />
    </div>
    <div class="message">Login Please</div>
    <div class="form">
      <div class="item" :class="isUserNameError ? 'error' : ''">
        <input class="account" placeholder="account here..." v-model="form.username" type="email" />
      </div>
      <div class="item" :class="isUserPasswordError ? 'error' : ''">
        <input
          class="password"
          placeholder="password here..."
          v-model="form.password"
          type="password"
        />
        <i class="iconfont icon-send" @click="handleLogin"></i>
      </div>
    </div>
  </div>
</template>
<script>
import { mapGetters } from 'vuex';
 
export default {
  data() {
    return {
      pass: false,
      isUserNameError: false,
      isUserPasswordError: false,
      form: {
        username: '',
        password: '',
      },
    };
  },
  computed: {
    ...mapGetters(['tagWel']),
  },
  methods: {
    handleLogin() {
      if (this.form.username === '') {
        this.isUserNameError = true;
        setTimeout(() => {
          this.isUserNameError = false;
        }, 1000);
        return;
      } else if (this.form.password === '') {
        this.isUserPasswordError = true;
        setTimeout(() => {
          this.isUserPasswordError = false;
        }, 1000);
        return;
      }
      this.$store.dispatch('LoginByUsername', this.loginForm).then(() => {
        this.pass = true;
        setTimeout(() => {
          this.$router.push(this.tagWel);
        }, 1000);
      });
    },
  },
};
</script>
<style lang="scss" scoped>
@use './login.scss';
</style>