详解axios在vue中的简单配置与使用


Posted in Javascript onMay 10, 2017

一、axios 简介

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

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

二、引入方式:

npm:

$ npm install axios
//淘宝源
$ cnpm install axios

bower:

$ bower install axios

cdn:

<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

三、vue中axios的配置

之前那个开源项目一开始就打算用axios,在网上找了好多文章与攻略,发现好多都不太详细,所以打算自己动手配置一个,(不要怂,撸起袖子就是干)。

我的配置:

import axios from 'axios'
import qs from 'qs'
import * as _ from '../util/tool'
axios.defaults.timeout = 5000;            //响应时间
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded;charset=UTF-8';      //配置请求头
axios.defaults.baseURL = '你的接口地址';  //配置接口地址
//POST传参序列化(添加请求拦截器)
axios.interceptors.request.use((config) => {
 //在发送请求之前做某件事
  if(config.method === 'post'){
    config.data = qs.stringify(config.data);
  }
  return config;
},(error) =>{
   _.toast("错误的传参", 'fail');
  return Promise.reject(error);
});
//返回状态判断(添加响应拦截器)
axios.interceptors.response.use((res) =>{
 //对响应数据做些事
  if(!res.data.success){
    // _.toast(res.data.msg);
    return Promise.reject(res);
  }
  return res;
}, (error) => {
  _.toast("网络异常", 'fail');
  return Promise.reject(error);
});
//返回一个Promise(发送post请求)
export function fetch(url, params) {
  return new Promise((resolve, reject) => {
    axios.post(url, params)
      .then(response => {
        resolve(response.data);
      }, err => {
        reject(err);
      })
      .catch((error) => {
        reject(error)
      })
  })
}

四、vue中使用配置好的axios

export default {
  /**
   * 用户登录
   */
  Login(params) {
    return fetch('/users/api/userLogin', params)
  }, 
  /**
   * 用户注册
   */
  Regist(params) {
    return fetch('/users/api/userRegist', params)
  },
  /**
   * 发送注册验证码
   */
  RegistVerifiCode(tellphone) {
    return fetch('/users/api/registVerifiCode', {tellphone: tellphone})
  },
  ......
}

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

Javascript 相关文章推荐
JS实现self的resend
Jul 22 Javascript
表单的焦点顺序tabindex和对应enter键提交
Jan 04 Javascript
JavaScript中的连字符详解
Nov 28 Javascript
js 鼠标移动显示图片的简单实例
Dec 25 Javascript
JavaScript之数组(Array)详解
Apr 01 Javascript
JavaScript中数据结构与算法(二):队列
Jun 19 Javascript
Bootstrap富文本组件wysiwyg数据保存到mysql的方法
May 09 Javascript
整理一下常见的IE错误
Nov 18 Javascript
使用layer弹窗和layui表单实现新增功能
Aug 09 Javascript
详解angular2.x创建项目入门指令
Oct 11 Javascript
用jQuery将JavaScript对象转换为querystring查询字符串的方法
Nov 12 jQuery
浅谈layer弹出层按钮颜色修改方法
Sep 11 Javascript
jQuery+PHP+Mysql实现抽奖程序
Apr 12 #jQuery
JavaScript实现form表单的多文件上传
Mar 27 #Javascript
Vue.js使用$.ajax和vue-resource实现OAuth的注册、登录、注销和API调用
May 10 #Javascript
利用PM2部署node.js项目的方法教程
May 10 #Javascript
全面解析vue中的数据双向绑定
May 10 #Javascript
利用forever和pm2部署node.js项目过程
May 10 #Javascript
javascript简单链式调用案例分析
May 10 #Javascript
You might like
php 操作符与控制结构
2012/03/07 PHP
浅析php中常量,变量的作用域和生存周期
2013/08/10 PHP
PHP Mysqli 常用代码集合
2016/11/12 PHP
JavaScript DOM 添加事件
2009/02/14 Javascript
JS的replace方法介绍
2012/10/20 Javascript
jQuery图片滚动图片的效果(另类实现)
2013/06/02 Javascript
通过AJAX的JS、JQuery两种方式解析XML示例介绍
2013/09/23 Javascript
JavaScript中日期的相关操作方法总结
2015/10/24 Javascript
JavaScript判断是否是微信浏览器
2016/06/13 Javascript
JavaScript html5 canvas实现图片上画超链接
2017/10/20 Javascript
Vue filter介绍及详细使用
2018/04/04 Javascript
node实现基于token的身份验证
2018/04/09 Javascript
vue下使用nginx刷新页面404的问题解决
2019/08/02 Javascript
vue 中的 render 函数作用详解
2020/02/28 Javascript
Jquery ajax书写方法代码实例解析
2020/06/12 jQuery
JavaScript实现alert弹框效果
2020/11/19 Javascript
vant时间控件使用方法详解
2020/12/24 Javascript
python重试装饰器示例
2014/02/11 Python
Python爬取网易云音乐热门评论
2017/03/31 Python
python批量下载网站马拉松照片的完整步骤
2018/12/05 Python
python 并发编程 非阻塞IO模型原理解析
2019/08/20 Python
Python编写memcached启动脚本代码实例
2020/08/14 Python
Python中的None与 NULL(即空字符)的区别详解
2020/09/24 Python
CSS3 input框的实现代码类似Google登录的动画效果
2020/08/04 HTML / CSS
肯尼亚网上商城:Kilimall
2016/08/20 全球购物
会话Bean的种类
2013/11/07 面试题
如何利用XMLHTTP检测URL及探测服务器信息
2013/11/10 面试题
医学毕业生自我鉴定
2013/10/30 职场文书
大学生写自荐信的技巧
2014/01/08 职场文书
采购求职信
2014/03/17 职场文书
大学专科自荐信
2014/06/17 职场文书
教师演讲稿开场白
2014/08/25 职场文书
学党史心得体会
2014/09/05 职场文书
小学竞选班长演讲稿
2014/09/09 职场文书
毕业生就业推荐表自我评价
2015/03/02 职场文书
python套接字socket通信
2022/04/01 Python