vue中promise怎么用?

发布于 2022-09-11 14:30:50 字数 576 浏览 9 评论 0

//登录

      this.$store.dispatch("Login", this.loginForm).then(info => {
          this.loginloading = false;
          return new Promise((resolve, reject) => {
          //登录成功后获取token
            GetAssessTokenInfo(name, psd)
              .then(response => {                  
                resolve(response);
              })
              .catch(error => {
                reject(error);
              });
          });
        })
        .catch(() => {
        });
    

我想在登录成功后的回调里,发送获取token的协议,正确的promise写法该怎么写?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

吖咩 2022-09-18 14:30:50

store.js

import { login  } from '@/api/user'
 
const user = {
  state: {
    token: ''
  },
  mutations: {
    SET_TOKEN: (state, data) => {
      state.token= data
    }
  },
  actions: {
    Login({ commit }, userInfo) {
      return new Promise((resolve, reject) => {
        login(userInfo)
          .then(response => {
           const data = response.data
           commit('SET_TOKEN', data.token)
            resolve(response )
          })
          .catch(error => {
            reject(error)
          })
      })
    },

    // 前端 登出 清除本地token 不访问接口
    FedLogOut({ commit }) {
      return new Promise(resolve => {
        commit('SET_TOKEN', '')
      
        resolve()
      })
    }
  }
}

export default user

调用

 this.$store.dispatch("Login", this.loginForm).then(info => {
  // 你的代码 
}).catch(err=>{});
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文