使用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 相关文章推荐
页面中body onload 和 window.onload 冲突的问题的解决
Jul 01 Javascript
Extjs学习笔记之二 初识Extjs之Form
Jan 07 Javascript
JS按位非(~)运算符与~~运算符的理解分析
Jul 31 Javascript
jquery动态添加删除(tr/td)
Feb 09 Javascript
基于jquery编写的放大镜插件
Mar 23 Javascript
jQuery短信验证倒计时功能实现方法详解
May 25 Javascript
使用JavaScript为一张图片设置备选路径的方法
Jan 04 Javascript
Vue.js实现一个漂亮、灵活、可复用的提示组件示例
Mar 17 Javascript
Puppeteer环境搭建的详细步骤
Sep 21 Javascript
angular 服务随记小结
May 06 Javascript
vue-test-utils初使用详解
May 23 Javascript
详解小程序如何改变onLoad的执行时机
Nov 01 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
php array_flip() 删除数组重复元素
2009/01/14 PHP
邮箱正则表达式实现代码(针对php)
2013/06/21 PHP
使用PHP强制下载PDF文件示例
2014/01/17 PHP
smarty高级特性之过滤器的使用方法
2015/12/25 PHP
Windows2003下php5.4安装配置教程(Apache2.4)
2016/06/30 PHP
另类调用flash无须激活的方法
2006/12/27 Javascript
30个最好的jQuery 灯箱插件分享
2011/04/25 Javascript
js浮动图片的动态效果
2013/07/10 Javascript
JavaScript+CSS控制打印格式示例介绍
2014/01/07 Javascript
document.write的几点使用心得
2014/05/14 Javascript
AngularJS基础 ng-class-odd 指令示例
2016/08/01 Javascript
AngularJS基础 ng-mouseenter 指令示例代码
2016/08/02 Javascript
vue实现简单的MVVM框架
2018/08/05 Javascript
vue通过滚动行为实现从列表到详情,返回列表原位置的方法
2018/08/31 Javascript
详解在vue-cli中使用graphql即vue-apollo的用法
2018/09/08 Javascript
angularJs使用ng-repeat遍历后选中某一个的方法
2018/09/30 Javascript
JS执行控制之节流模式实例分析
2018/12/21 Javascript
Vue.js组件实现选项卡以及切换特效
2019/07/24 Javascript
关于layui 弹出层一闪而过就消失的解决方法
2019/09/09 Javascript
js+canvas实现五子棋小游戏
2020/08/02 Javascript
vue keep-alive实现多组件嵌套中个别组件存活不销毁的操作
2020/10/30 Javascript
JavaScript 获取滚动条位置并将页面滑动到锚点
2021/02/08 Javascript
Python使用MYSQLDB实现从数据库中导出XML文件的方法
2015/05/11 Python
解决python有时候import不了当前的包问题
2019/08/28 Python
Python实现动态循环输出文字功能
2020/05/07 Python
canvas需要在标签里直接定义宽高
2014/12/17 HTML / CSS
有趣的睡衣和礼物:LazyOne
2019/11/27 全球购物
Static Nested Class 和 Inner Class的不同
2013/11/28 面试题
医院总经理岗位职责
2014/02/04 职场文书
市场推广策划方案
2014/06/02 职场文书
团队精神口号
2014/06/06 职场文书
总经理岗位职责说明书
2014/07/30 职场文书
安全伴我行演讲稿
2014/09/04 职场文书
环境工程专业毕业生求职信
2014/09/30 职场文书
现役军人家属慰问信
2015/03/24 职场文书
聊聊SpringBoot自动装配的魔力
2021/11/17 Java/Android