使用async await 封装 axios的方法


Posted in Javascript onJuly 09, 2018

es6 的promise 逐步解决了层层回调的问题,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 }

上述代码中,首先采用try,catch 捕获请求的错误, 如果网络状态差,服务器错误等 ,然后在请求成功状态中,亦可统一处理请求代码,这个可以根据具体项目处理,上例表示code=0的时候为结果正确状态.

使用可以参考如下,以vue项目为例:

import { api } from 'common/js/api'

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

有时候我们可能想比如错误处理能通过vue的一些组件比如toast这样的弹出,但是这个api.js不是在项目中,那该如何用呢, 下面以vue项目为例简述:

有些ui库,比如element ui这种,已经将toast这种做成了插件,可以直接用this示例打开弹窗

<template>
 <el-button type="text" @click="open">点击打开 Message Box</el-button>
</template>

<script>
 export default {
  methods: {
   open() {
    this.$alert('这是一段内容', '标题名称', {
     confirmButtonText: '确定',
     callback: action => {
      this.$message({
       type: 'info',
       message: `action: ${ action }`
      });
     }
    });
   }
  }
 }
</script>

以上代码摘自element Ui ,如果想全局处理,在api.js中,如何获取vue的this示例呢,在main.js里面,可以将vue实例挂载在window对象上

/* eslint-disable no-new */
window.wm = new Vue({
 el: '#app',
 router,
 render: h => h(App),
})

那么回到刚刚的api.js ,则可以直接在resolve 或者catch的情况下,调用 window.wm.$alert,这样就可以借用vue的插件形式调用弹窗组件了.

如果没有这种用this调用的 弹窗组件,我们也可以写一个放在app.vue下, 然后通过vuex全局控制,

那么可以在api.js中引入store

import store from '../store'

在catch 或者 resolve条件下

store.commit('showDialog',{true,'请求出错'})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
return false;和e.preventDefault();的区别
Jul 11 Javascript
javaScript NameSpace 简单说明介绍
Jul 18 Javascript
jQuery 追加元素的方法如append、prepend、before
Jan 16 Javascript
用原生JS获取CLASS对象(很简单实用)
Oct 15 Javascript
JS中获取函数调用链所有参数的方法
May 07 Javascript
谈谈JSON对象和字符串之间的相互转换JSON.stringify(obj)和JSON.parse(string)
Oct 01 Javascript
dul无法加载bootstrap实现unload table/user恢复
Sep 29 Javascript
Vue2组件tree实现无限级树形菜单
Mar 29 Javascript
Vue组件选项props实例详解
Aug 18 Javascript
浅谈React + Webpack 构建打包优化
Jan 23 Javascript
jQuery实现的简单图片轮播效果完整示例
Feb 08 jQuery
详解Webpack-dev-server的proxy用法
Sep 08 Javascript
bootstrap 弹出框modal添加垂直方向滚轴效果
Jul 09 #Javascript
jQuery实现简单复制json对象和json对象集合操作示例
Jul 09 #jQuery
JS实现图片旋转动画效果封装与使用示例
Jul 09 #Javascript
JavaScript的Object.defineProperty详解
Jul 09 #Javascript
Vue2.0仿饿了么webapp单页面应用详细步骤
Jul 08 #Javascript
mac上配置Android环境变量的方法
Jul 08 #Javascript
vue.js使用watch监听路由变化的方法
Jul 08 #Javascript
You might like
JoshChen_php新手进阶高手不可或缺的规范介绍
2013/08/16 PHP
利用yahoo汇率接口实现实时汇率转换示例 汇率转换器
2014/01/14 PHP
PHP中source #N问题的解决方法
2014/01/27 PHP
PHP和Shell实现检查SAMBA与NFS Server是否存在
2015/01/07 PHP
PHP获取真实客户端的真实IP
2017/03/07 PHP
解决AJAX中跨域访问出现'没有权限'的错误
2008/08/20 Javascript
javascript replace()正则替换实现代码
2010/02/26 Javascript
QUnit jQuery的TDD框架
2010/11/04 Javascript
快速解决jquery之get缓存问题的最简单方法介绍
2013/12/19 Javascript
利用JS判断用户是否上网(连接网络)
2013/12/23 Javascript
JavaScript利用构造函数和原型的方式模拟C#类的功能
2014/03/06 Javascript
JavaScript调试技巧之console.log()详解
2014/03/19 Javascript
JavaScript数组各种常见用法实例分析
2015/08/04 Javascript
JS实现的驼峰式和连字符式转换功能分析
2016/12/21 Javascript
微信小程序技巧之show内容展示,上传文件编码问题
2017/01/23 Javascript
vue params、query传参使用详解
2017/09/12 Javascript
vue+element-ui集成随机验证码+用户名+密码的form表单验证功能
2018/08/05 Javascript
Vue 实现展开折叠效果的示例代码
2018/08/27 Javascript
JavaScript实现预览本地上传图片功能完整示例
2019/03/08 Javascript
python中getattr函数使用方法 getattr实现工厂模式
2014/01/20 Python
Python中的并发编程实例
2014/07/07 Python
Python编写电话薄实现增删改查功能
2016/05/07 Python
python实现对excel进行数据剔除操作实例
2017/12/07 Python
python微信公众号开发简单流程
2018/03/23 Python
python 实现在txt指定行追加文本的方法
2018/04/29 Python
详解python 中in 的 用法
2019/12/12 Python
实列教程 一款基于jquery和css3的响应式二级导航菜单
2014/11/13 HTML / CSS
html5 自定义播放器核心代码
2013/12/20 HTML / CSS
巴西电子、家电、智能手机购物网站:Girafa
2019/06/04 全球购物
诺思信科技(南京)有限公司.NET笔试题答案
2013/07/06 面试题
EJB3.1都有哪些改进
2012/11/17 面试题
大学教师年终总结的自我评价
2013/10/29 职场文书
土木工程师岗位职责
2013/11/24 职场文书
大学生实习证明范本
2014/01/15 职场文书
学习之星事迹材料
2014/05/17 职场文书
行政上诉状范文
2015/05/23 职场文书