Vue.js axios
1.安装与引入
- Axios 是一个基于 promise 的 HTTP 库,可以用在浏览器和 node.js 中,官方文档
- 在HTML文件中引入
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
- 在脚手架中使用
//安装axios
npm install axios -S
//引入
import axios from 'axios'
2.基本使用
- axios()方法接收一个对象,在对象中指定请求方式和提交参数
<script>
//get请求参数
var query = {q:'vue',sort:"stars"}
//post请求参数
var data = {}
//token
var token = "xvcxvcxvcxv"
//发起请求
axios({
method:'get',//设置请求方法
baseURL:'http://127.0.0.1:80', //将自动加在 `url` 前面,除非 `url` 是一个绝对 URL
url:'/test',//是用于请求的服务器 URL
//params:query,//适用于get方法 相当于在url后面拼接 ?wd=js
data:{},//post请求的数据
headers:{ //即将被发送的自定义请求头
'Authorization':token, //为请求添加token
'X-Requested-With': 'XMLHttpRequest', //Ajax 请求
},
timeout: 1000,//如果请求花费的时间了超过 `timeout` 的时间,请求将被中断,并触发catch
responseType: 'json', // 默认json
}).then(res => {
//成功回调
console.log(res)
}).catch(err => {
//失败回调
console.log(err)
})
</script>
- 常用的配置项
| 参数 | 说明 |
|---|---|
| method | 请求方式,默认get |
| url | 请求地址 |
| params | get请求的query参数,数据类型为对象类型 |
| data | post请求的参数 |
| baseURL | baseURL 将自动加在 url 前面,除非 url 是一个绝对 URL |
| headers | 即将被发送的自定义请求头,例如token,数据类型为对象类型 |
| timeout | 指定请求超时的毫秒数,请求将被中断,并触发catch |
| responseType | 期望服务器响应的数据类型,默认json(标准格式就应该是json,即使是其他格式,也应该封装到json内) |
- 方法别名:将配置项中重要的3个参数(method,url,data)抽离出来,让代码更直观
axios.get(url[, config])
axios.post(url[, data[, config]])
3.响应结构
- axios请求的响应包含以下信息:
| 属性 | 说明 |
|---|---|
| data | 服务器提供的响应数据 |
| status | HTTP 状态码 例如200 |
| statusText | 来自服务器响应的 HTTP 状态信息 例如 "OK" |
| headers | 服务器响应的头 |
| config | 当前请求的配置信息 |

4.并发
- 使用axios.all([promiase,promiase2])发起并发请求,待所有请求都回来后统一处理
<script>
new Vue({
el:"#app",
data: {
},
created(){
//直接读取返回结果
this.getAllData()
//使用spread处理返回结果
this.getAllData2()
},
methods: {
getAllData(){
//接收2个promise对象
axios.all([this.getData(), this.getData2()])
.then(function(resArr){
//返回结果放入数组中
console.log('res1',resArr[0].data)
console.log('res2',resArr[1].data)
})
},
getAllData2(){
//接收2个promise对象
axios.all([this.getData(), this.getData2()])
.then(axios.spread(function (res1, res2) {
// 两个请求现在都执行完成
console.log('res1', res1.data)
console.log('res2', res2.data)
}))
},
getData(){
//返回promise对象
return axios.get('http://127.0.0.1:8086/getDouble?val=5')
},
getData2(){
//返回promise对象
return axios.get('http://127.0.0.1:8086/getTriple?val=10')
}
}
})
</script>
5.配置默认值
- 给axios本身配置默认值
//入口文件
import Vue from 'vue'
import axios from 'axios'
//统一配置接口域名
axios.defaults.baseURL = 'https://api.example.com'
//统一添加token
axios.defaults.headers.common['Authorization'] = window.localStorage.getItem("token")
//其他
//axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded'
axios.defaults.timeout = 2500
- 给axios实例配置默认值
//创建实例
const instance = axios.create({
//默认配置
baseURL: 'https://api.example.com'
});
// 默认配置
instance.defaults.headers.common['Authorization'] = AUTH_TOKEN
instance.defaults.timeout = 2500
//在vue中为了使所有的组件都能调用这个实例,可将其挂载到vue的原型链中
Vue.prototype.$ajax = instance
- 优先级:请求配置 > 实例配置 > 全局配置
6.拦截器
- 含义:在请求或响应被 then 或 catch 处理前拦截它们,一般用于处理公共逻辑,例如请求时统一添加token,请求失败时统一弹窗提示等等
- 可以给axios本身添加拦截器,还可以给axios实例添加拦截器
- 注意:在响应拦截器中,请求失败(404,401,跨域)将执行第二个回调
//入口文件
import Vue from 'vue'
import axios from 'axios'
// 请求拦截器
axios.interceptors.request.use(function (config) {
// 在发送请求之前做些什么
config.headers.common['Authorization'] = window.localStorage.getItem("token")
return config;
}, function (error) {
// 对请求错误做些什么
return Promise.reject(error);
});
// 响应拦截器
axios.interceptors.response.use(function (response) {
// 对响应数据做点什么
return response;
}, function (error) {
// 对响应错误做点什么
// 未登陆或者登陆过期,跳转登陆页面
return Promise.reject(error);
});
Vue.js axios的更多相关文章
- (vue.js)axios interceptors 拦截器中添加headers 属性
(vue.js)axios interceptors 拦截器中添加headers 属性:http://www.codes51.com/itwd/4282111.html 问题: (vue.js)axi ...
- FastAPI实践项目:SayHello(FastAPI + vue.js + axios + element ui)
目录 简介 翻版 VS 本尊 后端服务 源码 接下来 简介 这次带来的是FastAPI + vue.js + axios + element ui (一个html文件里使用的) 实现的<Flas ...
- vue.js axios使用
1. 自定义配置 /** * Created by superman on 17/2/16. * http配置 */ import axios from 'axios' import utils fr ...
- asp.net mvc + vue.js + axios.js
1.新建一个 MVC 应用程序 2.右键解决方案 添加VUE 3.搜索vue 1.安装axios.js ,用于数据请求,get , post axios
- .net core3.1 webapi + vue.js + axios实现跨域
我所要讲述的是,基于.net core3.1环境下的webapi项目,如何去使用axios对接前端的vue项目 既然谈到axios,这里贴出axios的官方文档地址: http://www.axios ...
- vue.js - axios Get、Post方法传参给 .net core webapi。
一:axios中是 Get请求: 1:在vue项目中通过params属性携带数据: let _self = this; axios({ method:'get', url:'http://localh ...
- vue.js axios实现跨域http请求接口
跨域post实例,用到了qs组件来避开ajax信使请求,并兼容Android. import axios from 'axios'; import qs from 'qs'; axios.post(' ...
- Vue.js 2.x笔记:服务请求axios(8)
1. axios简介 vue2.0之后,推荐使用axios. axios官方地址:https://github.com/axios/axios 2. axios安装 npm安装: npm instal ...
- 学习随笔:Vue.js与Django交互以及Ajax和axios
1. Vue.js地址 Staticfile CDN(国内): https://cdn.staticfile.org/vue/2.2.2/vue.min.js unpkg:会保持和npm发布的最新的版 ...
- 推荐vue.js、layer.js、axios.js
都是很简单又很实用的东西. vue.js,前端双向绑定框架. layer.js,前端遮罩层框架.(layui的一部分,可单独使用) axios.js,异步请求框架,用起来比jQuery的ajax舒服一 ...
随机推荐
- ASP.NET Core – Program.cs and Startup.cs 小笔记
前言 ASP.NET Core 6.0 以后, 默认模板去掉了 Program.cs 的 namespace, class 和 Startup.cs, 一开始看会有点懵. 这篇大概记入一下, prog ...
- Serilog文档翻译系列(五) - 编写日志事件
日志事件通过 Log 静态类或 ILogger 接口上的方法写入接收器.下面的示例将使用 Log 以便语法简洁,但下面显示的方法同样可用于接口. Log.Warning("Disk quot ...
- 第22天:安全开发-PHP应用&留言板功能&超全局变量&数据库操作&第三方插件引用
#数据库操作-mysqli函数&增删改查 PHP函数:连接,选择,执行,结果,关闭等 参考:https://www.runoob.com/php/php-ref-mysqli.html 常用: ...
- 异步解析文件报错 NoSuchFileException
问题描述:同步上传解析文件超时,修改为异步解析后找不到 文件 java.nio.file.NoSuchFileException 原因:异步文件上传,主线程结束后,临时目录的文件会被清理掉,子线程此时 ...
- 【赵渝强老师】什么是Spark SQL?
一.Spark SQL简介 Spark SQL是Spark用来处理结构化数据的一个模块,它提供了一个编程抽象叫做DataFrame并且作为分布式SQL查询引擎的作用. 为什么要学习Spark SQL? ...
- MySQL9的3个新特性
本文讲解MySQL9的3个新特性:支持将JSON输出保存到用户变量.支持准备语句以及支持面向AI的向量存储. 17.12 MySQL9新特性1--支持将JSON输出保存到用户变量 从MySQL 9版 ...
- vue前端开发仿钉图系列(4)右侧行政区绘制的开发详解
行政区绘制是基于高德地图的api,需要在高德提供的代码基础上做好html代码在vue页面上的适配.核心功能就是选择省市区,可以根据需要绘制对应选中的地图图层.整理总结不易,如需全部代码,请联系我150 ...
- 1. 说一下 vue 的父子传参 ?
主要实现的方式: 1. 第一种方法 ,在子组件标签使用自定义属性="参数"和自定义事件,在子组件内使用 props 接受自定义属性 :如果子组件要修改参数,不能直接修改,因为 vu ...
- Linux查看CPU核数
**方法一:通过proc文件系统 获取cpu总数量 命令如下 ** cat /proc/cpuinfo |grep processor 方法二:nproc命令 nproc 方法三:lscpu 显示CP ...
- Litmus 实践:让群魔在混沌中乱舞,看 K8s 能撑到何时
对于云服务而言,如果系统出现异常,将会带来很大的损失.为了最大程度地降低损失,我们只能不断探寻系统何时会出现异常,甚至缩小到某些特定参数变化是否会造成系统异常.然而随着云原生的发展,不断推进着微服务的 ...