zoukankan      html  css  js  c++  java
  • Vue(二十三)vuex + axios + 缓存 运用 (以登陆功能为例)

    (一)axios 封装

    (1)axios拦截器

     可以在axios中加入加载的代码。。。

    (2)封装请求

    后期每个请求接口都可以写在这个里面。。。 

    (二)vuex

     

     user.js 

    import { login } from '@/api/login'
    
    const state = {
      userInfo: null,
    }
    
    const getters = {
      get_userInfo (state) {
        let userInfo = state.userInfo
        if (!userInfo) {
          userInfo = window.localStorage.getItem('userInfo')
        }
        return JSON.parse(userInfo)
      }
    }
    
    const mutations = {
      set_userInfo (state, data) {
        state.userInfo = data
        window.localStorage.setItem('userInfo', state.userInfo)
      }
    }
    
    const actions = {
      Login (context, {username, password}) {
        return new Promise((resolve, reject) => {
          login(username, password).then(response => {
            context.commit('set_userInfo', response.data.rtnInfo)
            resolve(response)
          }, error => {
            reject(error)
          })
        })
      }
    }
    
    export default {
      state,
      getters,
      mutations,
      actions
    }

    (1)创建一个state - userInfo  保存用户信息

    (2)getters - get_userInfo 获取用户信息,读取缓存

    (3)mutations - set_userInfo  每次登录,将用户信息保存在缓存中

    (4)action - Login 调用api中的login接口

             进行登录操作

    在index.js 中注入 user

    在main.js中 引入store - index.js

     (三)组件中运用

    Login.Vue

    <template>
      <div id="login">
        <img class="login-icon01" src="../../static/images/login02.png">
        <el-form class="login-form" :model="ruleForm" ref="ruleForm">
          <el-form-item>
            <el-input type="text" placeholder="用户名" v-model="ruleForm.username" prefix-icon="iconfont icon-user" clearable auto-complete="off"></el-input>
          </el-form-item>
          <el-form-item>
            <el-input type="password" placeholder="密码" v-model="ruleForm.password" prefix-icon="iconfont icon-password" clearable auto-complete="off"></el-input>
          </el-form-item>
          <el-form-item>
            <el-button class="login-btn" type="primary" :loading="loading" @click="submitForm(ruleForm)">登录</el-button>
          </el-form-item>
        </el-form>
        <img class="login-icon03" src="../../static/images/login01.png">
      </div>
    </template>
    
    <script>
    export default {
      data () {
        return {
          loading: false,
          // urlIbest: this.$store.state.User.urlIbest,
          ruleForm: {
            username: '',
            password: ''
          }
        }
      },
      methods: {
        submitForm (formName) {
          this.loading = true
          if (formName.username === '' || formName.password === '') {
            this.$message.error('用户名或密码不能为空')
            this.loading = false
          } else {
            // 登录
            this.$store.dispatch('Login', {'username': formName.username, 'password': formName.password}).then(response => {
              if (response.data && response.data.rtnCode === '00000000') {
                this.loading = false
                this.$router.push('/home')
              } else {
                this.$message.error(response.data.rtnMsg)
                this.loading = false
              }
            })
          }
        }
      }
    }
    </script>
    
    <style lang="less" scoped>
      #login {
        background-color: #2f329f;
        position: fixed;
        top:0;
        left:0;
        right:0;
        bottom:0;
        margin:auto;
        .login-form{
           80%;
          padding: 30px 10%;
          background: rgba(47,50,159,.3);
          position: absolute;
          z-index: 8;
          top: 120px;
          .el-input__inner{
            padding-top:8px;
            padding-bottom:8px;
            background-color:transparent!important;
            color:#fff;
          }
          .login-btn{
            100%;
            background-color:#fff;
            color:#2f329f;
            border:none;
            margin-top:20px;
          }
        }
        .login-icon01{
            position: absolute;
             20%;
            right: 15%;
            top: 60px;
            z-index: 10;
        }
        .login-icon02{
            position: absolute;
             50%;
            bottom:20px;
            left:0;
            right:0;
            margin:auto;
            z-index:2;
        }
        .login-icon03{
            position: absolute;
             110%;
            left: 0;
            right: 0;
            bottom: 0;
            margin-left: -5%;
            z-index: 1;
        }
      }
    </style>

    在登录提交中,调用store中方法

    this.$store.dispatch('Login', {'username': formName.username, 'password': formName.password})

    传入用户名和密码

  • 相关阅读:
    Fiddler无法抓取HTTPS的问题,Fiddler证书无法安装终极解决方案,
    锤子手机做appium自动化测试时,运行脚本总是弹出警告框的问题
    jmeter4+win10+jdk1.8环境下,jmeter输入中文就卡死的问题
    jenkins构建邮件自动发送,测试邮件发送成功,构建项目邮件发送不成功的问题
    Jenkins安装部署
    Appium中wait_activity的使用以及XPATH定位
    Appium连接夜神模拟器,模拟手势点击(tap)
    Appium如何查看webview上元素
    Appium启动淘宝APP,输入搜索内容
    Error while obtaining UI hierarchy XML file: com.android.ddmlib.SyncException: Remote object doesn't
  • 原文地址:https://www.cnblogs.com/yulingjia/p/8986387.html
Copyright © 2011-2022 走看看