码迷,mamicode.com
首页 > 移动开发 > 详细

vue项目使用async await 封装 axios

时间:2019-05-22 13:59:39      阅读:605      评论:0      收藏:0      [点我收藏+]

标签:methods   common   creat   nbsp   通过   api   mes   一个   ISE   

es8的async await让异步变成了同步的写法,在vue中,可以通过封装axios,使得所有的请求都可以使用同步的写法。

新建一个api.js文件,全局创建api实例

import axios from axios
const qs = require(qs)
const api = {
  async get (url, data) {
    try {
      let res = await axios.get(url, {params: data})
      res = res.data
      return new Promise((resolve) => {
        if (res.code === 0) {
          resolve(res)
        } else {
          resolve(res)
        }
      })
    } catch (err) {
      alert(服务器出错)
      console.log(err)
    }
  },
  async post (url, data) {
    try {
      let res = await axios.post(url, qs.stringify(data))
      res = res.data
      return new Promise((resolve, reject) => {
        if (res.code === 0) {
          resolve(res)
        } else {
          reject(res)
        }
      })
    } catch (err) {
      // return (e.message)
      alert(服务器出错)
      console.log(err)
    }
  },
}
export { api }

使用可以参考如下

  import { api } from common/js/api
  export default {
    data () {
      return {
        list: [],
      }
    },
    created () {
      this.getList()
    },
    methods: {
      async getList () {
        let {data} = await api.get(/test/list)
        console.log(data)
        this.list = data
      }
    },
  }

 

vue项目使用async await 封装 axios

标签:methods   common   creat   nbsp   通过   api   mes   一个   ISE   

原文地址:https://www.cnblogs.com/lhy-555/p/10905419.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!