axios学习和使用
网络请求的方式
传统的Ajax,基于XMLHttpRequest(不推荐)
- 配置调用方式混乱(回调地狱)
jQuery-Ajax (在vue开发中不推荐)
- 相对于传统的Ajax非常好用
- 但是jQuery的代码1w行,vue的代码1w行,在vue开发中,完全没有为了用网络请求就引用一个重量级的框架
axios(推荐)
- 在Vue-resource停止更新之后,axios是vue作者推荐的一款轻便的基于 promise 的 HTTP 库
认识Axios
- 可以理解为 ajax i/o system 的缩写
- 功能特点:
- 在浏览器中发送 XMLHttpRequests 请求
- 在 node.js 中发送 http请求
- 支持 Promise API
- 拦截请求和响应
- 转换请求和响应数据
- 。。。
- 支持多种请求方式:
- axios(config)
- axios.request(config)
- axios.get(url[, config])
- axios.delete(url[, config])
- axios.head(url[, config])
- axios.put(url[, data[, config]])
- axios.patch(url[, data[, config]])
发送基本请求
**发送get请求演示**
import axios from 'axios'
export default {
name:'app',
created(){ //在vue的生命周期函数中
//提问:为什么没有跨域的问题?
//1.没有请求参数
axios.get('http://123.207.32.32:8000/api/v1')
.then(res=>{
console.log(res);
}).catch(err=>{
console.log(err)
}) //2.有参数
axios.get('http://123.207.32.32:8000/api/v1',
{params:{type:'sell',page:1}})
.then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
})
}
}
**发送并发请求**
created(){ //在vue的生命周期函数中
axios.all([axios.get('http://123.207.32.32:8000/api'),
axios.get('http://123.207.32.32:8000/api')],
{params:{type:'sell',page:1}})
.then(axios.spread((res1,res2)=>{
console.log(res1);
console.log(res2);
}))
}
全局配置
- 在开发中可能很多参数都是固定的,这个时候我们可以进行一些抽取, 也可以利用axiox的全局配置
//提取全局的配置
axios.defaults.baseURL = 'http://123.207.32.32:8000'
//发送并请求
axios.all([axios.get('/api'),
axios.get('/home'),
{params:{type:'sell',page:1}}])
.then(axios.spread((res1,res2)={
console.log(res1);
console.log(res2);
}))
- 常见的全局配置
- 1.请求地址:url: '/user' 2.请求类型:method: 'get',
- 3.请根路径:baseURL: 'http://www.mt.com/api' 4.请求前的数据处理:transformRequest:[function(data){}],
- 5.请求后的数据处理:transformResponse: [function(data){}] 6.自定义的请求头:headers:{'x-Requested-With':'XMLHttpRequest'},
- 7.URL查询对象:params:{ id: 12 } 8.查询对象序列化函数:paramsSerializer: function(params){ }
- 9.request body:data: { key: 'aa'} 10.超时设置s:timeout: 1000,
- 11.跨域是否带Token:withCredentials: false 12.自定义请求处理:adapter: function(resolve, reject, config){},
- 13.身份验证信息:auth: { uname: '', pwd: '12'} 14.响应的数据格式 json / blob /document /arraybuffer / text / stream:responseType: 'json',
axios的实例
- 为什么要创建axios的实例呢?
- 当给该实例设置一些默认配置时, 这些配置就被固定下来了.但是后续开发中, 某些配置可能会不太一样.
- 这个时候, 我们就可以创建新的实例, 并且传入属于该实例的配置信息.
//创建新的实例
const axiosInstance =axios.create({
baseURL:'http://123.207.32.32:8000',
timeout:5000,
headers:{
'Content-Type':'application/x-www.from-urlencoded'
}
//发送网络请求
axiosInstance({
url:'/api',
method:'get',
}).then(res=>{
console.log(res);
}).catch(err=>{
console.log(err);
})
})
axios封装
//创建的axios文件中
import originAxios from 'axios'
export default function axios(option){
return new Promise((resolve,reject)={
//1.创建axios实例
const instance = originAxios.create({
baseURL:'/api',
timeout:5000,
headers:''
}); //2.传入的对象进行网络请求(optiond)
instance(option).then(res=>{
resolve(res);
}).catch(err=>{
reject(err);
})
//对第二步的简写(因为axios本身返回的就是一个Promise)
//去掉export下面return Promise的那一行
return instance(config)
})
}
Axios拦截器
- axios提供了拦截器,用于我们在发送每次请求或者得到相应后,进行对应的处理
**请求拦截**
instance.interceptors.request.use(config=>{
console.log('来到了request拦截的success中')
// 1.当发送网络请求时,在页面中添加了一个loading组件,作为动画 // 2. 某些请求要求用户必须登陆,判断用户是否有token,如果没有token跳转到login页面 // 3.对请求的参数进行序列化
config.data =qs.stringify(config.data)
console.log(config) //当拦截完了一定要记得将拦截返回
return config
}) use()中还有一个err参数,表示请求错误后的拦截,请求拦截中错误拦截比较少,通常都是配置相关的拦截,可能的错误比如请求超时时,可以将页面跳转到一个错误的页面中
**响应拦截**
响应的成功拦截中,主要是对数据进行过滤
instance.interceptors.response.use(response=>{
console.log("来到了response拦截success中");
return response.data
响应失败的拦截中,可以根据status判断报错的错误码,跳转到不同的错误提示页面
},err => {
console.log('来到了response拦截的failure中')
if( err && err.response){
switch(err.response.status){
case 400:
err.message = '请求错误',
break;
case 401:
err.message = '未授权的访问',
break;
}
}
return err
})
axios学习和使用的更多相关文章
- axios学习笔记
axios学习笔记axios文档源地址:https://github.com/axios/axios0.概念axios 在NPM上的描述是:Promise based HTTP client for ...
- axios 学习笔记
官方文档地址:https://github.com/axios/axios axios 是一个基于 Promise 的HTTP库,可以用在浏览器和 node.js 中 特性: • 从浏览器发起 XML ...
- axios学习 - 数据获取及渲染
在app.vue和main.js中引入axios(import axios from 'axios') 基本代码: axios.get('/axios.json') .then(function(re ...
- vue学习之ajax 简单快速使用axios
vue2.x 推荐使用axios 1.首先使用安装 npm install axios -S 2.在哪用在哪引入 import axios from 'axios' 或则在main.js 中引入 在申 ...
- axios浏览器异步请求方法封装 XMLHttpRequest
axios学习笔记defaults(浏览器端异步请求处理方式) 浏览器异步请求方法封装,主要使用XMLHttpRequest lib/adapters/xhr.js //入口 var utils = ...
- axios源码入口以及公用方法
axios学习笔记(公用方法) 源码地址 找到入口文件 axios/lib/axios.js var utils = require('./utils'); var bind = require('. ...
- defaults(默认配置)和mergeConfig(合并config方法)
axios学习笔记defaults(默认配置)和mergeConfig(合并config方法) 源码地址 找到入口文件 axios/lib/axios.js ... var mergeConfig = ...
- Vue2学习小记-给Vue2路由导航钩子和axios拦截器做个封装
1.写在前面 最近在学习Vue2,遇到有些页面请求数据需要用户登录权限.服务器响应不符预期的问题,但是总不能每个页面都做单独处理吧,于是想到axios提供了拦截器这个好东西,再于是就出现了本文. 2. ...
- vue学习目录 vue初识 this指向问题 vue组件传值 过滤器 钩子函数 路由 全家桶 脚手架 vuecli element-ui axios bus
vue学习目录 vue学习目录 Vue学习一之vue初识 Vue学习二之vue结合项目简单使用.this指向问题 Vue学习三之vue组件 Vue学习四之过滤器.钩子函数.路由.全家桶等 Vue学习之 ...
随机推荐
- 操作系统原理之I/O设备管理(第六章上半部分下)
五.I/O软件原理 输入输出软件的总体目标是将软件组织成一种层次结构 低层软件用来屏蔽硬件的具体细节 高层软件则主要是为用户提供一个简洁.规范的界面 设备管理的4个层次: 用户层软件 ->向系统 ...
- 从零开始构建Linux
目的:深入了解以Linux内核为基础的系统是如何组成,运行,以构建一个最基础的,纯净的系统. LFS构建步骤宿主机准备- linux操作系统安装- 使用独立硬盘,创建分区- 配置用户和组- 下载所有需 ...
- Python中使用moviepy进行视频分割
场景 moviepy官网: https://pypi.org/project/moviepy/ 是一个用于视频编辑的Python库:切割.连接.标题插入.视频合成.非线性编辑,视频处理和定制效果的创建 ...
- Delphi - 调用外部程序并阻塞到外部程序中
Delphi 调用外部程序并阻塞到外部程序中 背景说明: 前段时间开发一个数据转换的系统,业务逻辑中说明数据需要压缩成.tar.gz格式. 我在Windows系统下采用,先生成批处理文件,然后调用Wi ...
- 喜大普奔,两个开源的 Spring Boot + Vue 前后端分离项目可以在线体验了
折腾了一周的域名备案昨天终于搞定了. 松哥第一时间想到赶紧把微人事和 V 部落部署上去,我知道很多小伙伴已经等不及了. 1. 也曾经上过线 其实这两个项目当时刚做好的时候,我就把它们部署到服务器上了, ...
- MOOC C++笔记(二):类和对象基础
第二周:类和对象基础 面向对象程序设计的四个基本特点 抽象.封装.继承.多态. 面向对象程序设计的过程 1.从客观事物抽象出类 抽象出的事物带有成员函数与成员变量(类似于带函数的结构体) 成员变量和成 ...
- 编程必备基础知识|计算机组成原理篇(09):CPU的控制器和运算器
计算机基础方面的知识,对于一些非科班出身的同学来讲,一直是他们心中的痛,而对于科班出身的同学,很多同学在工作之后,也意识到自身所学知识的不足与欠缺,想回头补补基础知识.关于计算机基础的课程很多,内容繁 ...
- Python 2.X和3.X主要区别和下载安装
一.python 2.X和3.X的区别 https://wenda.so.com/q/1459639143721779?src=140 二.Python的下载安装 1.Python下载 在python ...
- 在linux服务器上装svn版本管理,自动部署代码到web项目
在linux服务器上装svn版本管理,自动部署代码到项目 1.安装svn服务器端 yum install subversion 从镜像下载安装svn服务器端 中间会提示是否ok,输入y,确认 ...
- APP自動化測試腳本1
package com.lemon.day01; import java.net.MalformedURLException; import java.net.URL; import java.uti ...