vue axios 简单封装以及思考


Posted in Javascript onOctober 09, 2018

axios 简介

axios 是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端,它本身具有以下特征:

--------------------------------------------------------------------------------
•从浏览器中创建 XMLHttpRequest
•从 node.js 发出 http 请求
•支持 Promise API
•拦截请求和响应
•转换请求和响应数据
•取消请求
•自动转换JSON数据
•客户端支持防止 CSRF/XSRF

先安装 axios

npm install axios

axios的详细介绍以及用法 就不多说了请 移步 github ➡️  https://github.com/axios/axios

下面是简单的封装一个 http.js, 在此说明  checkStatus 这个方法呢 是不一定需要的 ,根据个人的项目需求吧,也可以直接返回response,交给后面另行处理也行。

或者根据后端返回的状态,在里面进行处理 也行。

"use strict";
import axios from "axios";
import qs from "qs";
//添加请求拦截器
axios.interceptors.request.use(
 config => {
  return config;
 },
 error => {
  return Promise.reject(error);
 }
);
//添加响应拦截器
axios.interceptors.response.use(
 response => {
  return response;
 },
 error => {
  return Promise.resolve(error.response);
 }
);
axios.defaults.baseURL = "https://www.xxxx/api";
axios.defaults.headers.post["Content-Type"] = "application/json";
axios.defaults.headers.post["X-Requested-With"] = "XMLHttpRequest";
axios.defaults.timeout = 10000;
function checkStatus(response) {
 return new Promise((resolve, reject) => {
  if (
   response &&
   (response.status === 200 ||
    response.status === 304 ||
    response.status === 400)
  ) {
   resolve(response.data);
  } else {
   reject({
    state: "0",
    message: "网络异常"
   });
  }
 });
}
export default {
 post(url, params) {
  return axios({
   method: "post",
   url,
   data: params
  }).then(response => {
   return checkStatus(response);
  });
 },
 get(url, params) {
  params = qs.stringify(params);
  return axios({
   method: "get",
   url,
   params
  }).then(response => {
   return checkStatus(response);
  });
 }
};

在vue 项目中,main.js这个文件

import http from "./utils/http";
Vue.prototype.$http = http;

使用 helloworld.vue

...
methods: {
  async TestPost() {
   try {
    const res = await this.$http.post("/message/socketid", {
     account: "huangenai"
    });
    console.log(res);
   } catch (error) {
    console.log(error);
   }
  },
  async TestGet() {
   this.$http
    .get("/price")
    .then(res => {
     console.log(res);
    })
    .catch(error => {
     alert(error);
    });
  }
}
....

在main.js中将http.js import 进来 并暴露到全局使用,在任何vue 页面中 就不再需要 import http.js了,而直接通过 this.$http.post this.$http.get 来使用,在checkStatus中统一异步返回,顺便可以处理错误的情况。

个人思考:

checkStatus方法 返回了一个 Promise

链式结构的话看上面那个get的方法,this.$http.get(...).then(...).catch(...),如果then 里面又来一个 http请求 会一层包住一层。

如果使用了语法糖 async  await  ,虽然 看起来好像是简单了 不用 一层包住一层 层层嵌套,可是你必须要用到 try catch,如果出现异常 则直接到catch,不会再执行下面到方法。如果再实际业务中,就算出现了某一个http请求失败到情况,不影响下面的逻辑要继续跑下去呢,这个就不适用了。链式结构也是 如果catch到异常 也不会执行then 里面到方法了。

所以,是否把返回的Promise,全部都返回的是 resolve,那么 就不会说出现直接到了 catch 里面不执行以下的业务了逻辑了呢。而且如果使用了语法糖 await 代码看起来更加简洁 也不需要 try catch了, 这样的话 reject是不是就不需要用到了呢。

function checkStatus(response) {
 return new Promise(resolve => {
  if (
   response &&
   (response.status === 200 ||
    response.status === 304 ||
    response.status === 400)
  ) {
   resolve(response.data);
  } else {
   resolve({
    state: "0",
    message: "网络异常"
   });
  }
 });
}

个人觉得这两种方案各有优劣,实际应用中还是应该根据个人业务需求 业务情况而定。

Javascript 相关文章推荐
css图片自适应大小
Nov 28 Javascript
让任务管理器中的CPU跳舞的js代码
Nov 01 Javascript
让JavaScript 轻松支持函数重载 (Part 1 - 设计)
Aug 04 Javascript
Javascript 遮罩层和加载效果代码
Aug 01 Javascript
Js参数值中含有单引号或双引号问题的解决方法
Nov 06 Javascript
js中直接声明一个对象的方法
Aug 10 Javascript
jQuery $命名冲突解决方案汇总
Nov 13 Javascript
Javascript的表单与验证-非空验证
Mar 18 Javascript
webuploader模态框ueditor显示问题解决方法
Dec 27 Javascript
利用Javascript实现一套自定义事件机制
Dec 14 Javascript
微信小程序自定义prompt组件步骤详解
Jun 12 Javascript
Vue瀑布流插件的使用示例
Sep 19 Javascript
angularJS实现不同视图同步刷新详解
Oct 09 #Javascript
对angular 实时更新模板视图的方法$apply详解
Oct 09 #Javascript
AngularJs返回前一页面时刷新一次前面页面的方法
Oct 09 #Javascript
详解js模板引擎art template数组渲染的方法
Oct 09 #Javascript
angular4强制刷新视图的方法
Oct 09 #Javascript
Angular4.x Event (DOM事件和自定义事件详解)
Oct 09 #Javascript
Vue官方推荐AJAX组件axios.js使用方法详解与API
Oct 09 #Javascript
You might like
PHP清除数组中所有字符串两端空格的方法
2014/10/20 PHP
Django 中 cookie的使用
2017/08/17 PHP
YII2.0框架行为(Behavior)深入详解
2019/07/26 PHP
初学JavaScript第二章
2008/09/30 Javascript
JS格式化数字金额用逗号隔开保留两位小数
2013/10/18 Javascript
xmlhttp缓存清除的2种解决方法
2013/12/13 Javascript
js实现浮动在网页右侧的简洁QQ在线客服代码
2015/09/04 Javascript
jQuery事件的绑定、触发、及监听方法简单说明
2016/05/10 Javascript
基于Vue 实现一个中规中矩loading组件
2019/04/03 Javascript
解析JS在获取当前月的最后一天遇到的坑
2019/08/30 Javascript
基于Vue的商品主图放大镜方案详解
2019/09/19 Javascript
Vue项目环境搭建详细总结
2019/09/26 Javascript
jQuery实现简单聊天室
2020/02/08 jQuery
[02:27]2018DOTA2亚洲邀请赛趣味视频之钓鱼大赛 谁是垂钓冠军?
2018/04/05 DOTA
[52:20]DOTA2-DPC中国联赛正赛 SAG vs XGBO3 第一场 3月5日
2021/03/11 DOTA
Python 爬虫爬取指定博客的所有文章
2016/02/17 Python
python+matplotlib实现动态绘制图片实例代码(交互式绘图)
2018/01/20 Python
python实现单向链表详解
2018/02/08 Python
解决PyCharm的Python.exe已经停止工作的问题
2018/11/29 Python
python 求某条线上特定x值或y值的点坐标方法
2019/07/09 Python
python pygame实现滚动横版射击游戏城市之战
2019/11/25 Python
Python利用逻辑回归模型解决MNIST手写数字识别问题详解
2020/01/14 Python
Python3.7实现验证码登录方式代码实例
2020/02/14 Python
Django-migrate报错问题解决方案
2020/04/21 Python
Python 判断时间是否在时间区间内的实例
2020/05/16 Python
关于PySnooper 永远不要使用print进行调试的问题
2021/03/04 Python
自我评价怎么写正确呢?
2013/12/02 职场文书
交通安全演讲稿
2014/01/07 职场文书
运动会广播稿150字
2014/02/19 职场文书
优质护理服务演讲稿
2014/05/07 职场文书
销售类求职信
2014/06/13 职场文书
办护照工作证明
2014/10/01 职场文书
教师政风行风评议心得体会
2014/10/21 职场文书
门面租赁合同范文
2019/08/06 职场文书
二年级作文之动物作文
2019/11/13 职场文书
SqlServer数据库远程连接案例教程
2021/07/15 SQL Server