ajax是JQUERY封装的XMLHttprequest用来发送http请求
Axios简单点说它就是一个js库,支持ajax请求,发送axios请求功能更加丰富,丰富在哪不知道
1.npm使用方式
vue项目中 npm install axios
2.cdn方式
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
3.使用本地文件
<script src="js/axios.min.js"></script>
axios 带有拦截器功能:分别是请求拦截器 应答拦截器(就是响应拦截器)
第三种方式需要将axios文件下载到本地,下载方式
GITHUB上下载 地址 GitHub - axios/axios: Promise based HTTP client for the browser and node.js
在 GitHub 仓库页面,点击 "Code" 按钮,然后选择 "Download ZIP" 以下载包含所有文件的压缩文件。
解压下载的 ZIP 文件。
在解压后的文件夹中,你可以在 dist
文件夹中找到 axios.min.js
文件。
data:image/s3,"s3://crabby-images/4caff/4caff7f216c6747bb653b51dade77534d8266cc6" alt=""
data:image/s3,"s3://crabby-images/d2e0f/d2e0fdabca0b5552a20a65d62aa63e923066534d" alt=""
解压后点进去dist
文件夹中找到 axios.min.js
文件。
data:image/s3,"s3://crabby-images/4e5bb/4e5bb9657eb1415bddc7da16630586baec8a9342" alt=""
下面用VsCode练习下axios
1.GET无参
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<!-- 引入axios -->
<script src="js/axios.min.js"></script>
<!-- <script src="https://unpkg.com/axios/dist/axios.min.js"></script> -->
<!-- <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script> -->
</head>
<body>
<button οnclick="fn1()">使用axios发送get请求,无参数</button>
<script>
//get无参请求 axios格式: axios.get(url).then().catch().finally()
function fn1(){
var url="http://localhost:8000/api/v1/product/index";
axios.get(url).then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
}).finally(()=>{
console.log("一定执行的代码")
})
}
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/07994/0799479560d46867c42361eac6c991007176d171" alt=""
这是因为跨域问题
data:image/s3,"s3://crabby-images/ccd6e/ccd6eb8ab4be4ff245c41021077c9dac3d7a9493" alt=""
data:image/s3,"s3://crabby-images/2973b/2973bf018160a95df2fb18902e1ea10eccff1ee7" alt=""
2.GET请求带参数
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<!-- 引入axios -->
<script src="js/axios.min.js"></script>
<!-- <script src="https://unpkg.com/axios/dist/axios.min.js"></script> -->
<!-- <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script> -->
</head>
<body>
<button οnclick="fn1()">使用axios发送get请求,无参数</button>
<button οnclick="fn2()">使用axios发送get请求,带参数</button>
<script>
//get无参请求 axios格式: axios.get(url).then().catch().finally()
function fn1(){
var url="http://localhost:8000/api/v1/product/list";
axios.get(url).then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
}).finally(()=>{
console.log("一定执行的代码")
})
}
function fn2(){
var pType=1;
var pageNum=1;
var pageSize=3;
var url="http://localhost:8000/api/v1/product/list?pType="+pType+"\&pageNum="+pageNum+"\&pageSize="+pageSize;
axios.get(url).then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
}).finally(()=>{
console.log("一定执行的代码")
})
}
</script>
</body>
</html>
data:image/s3,"s3://crabby-images/cfa5c/cfa5cf5e44d2fb5be99d56c05b1039306f8325b7" alt=""
上面这样是传统传参方式
axios使用配置项目params
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<!-- 引入axios -->
<script src="js/axios.min.js"></script>
<!-- <script src="https://unpkg.com/axios/dist/axios.min.js"></script> -->
<!-- <script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script> -->
</head>
<body>
<button οnclick="fn1()">使用axios发送get请求,无参数</button>
<button οnclick="fn2()">使用axios发送get请求,带参数</button>
<button οnclick="fn3()">使用axios发送get请求,带参数,使用axios配置项方式</button>
<script>
//get无参请求 axios格式: axios.get(url).then().catch().finally()
function fn1(){
var url="http://localhost:8000/api/v1/product/list";
axios.get(url).then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
}).finally(()=>{
console.log("一定执行的代码")
})
}
function fn2(){
var pType=1;
var pageNum=1;
var pageSize=3;
var url="http://localhost:8000/api/v1/product/list?pType="+pType+"\&pageNum="+pageNum+"\&pageSize="+pageSize;
axios.get(url).then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
}).finally(()=>{
console.log("一定执行的代码")
})
}
function fn3(){
var pType=1;
var pageNum=1;
var pageSize=3;
var url="http://localhost:8000/api/v1/product/list";
axios.get(url,{
params:{
pType:pType,
pageNum:pageNum,
pageSize:pageSize
}
}).then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
}).finally(()=>{
console.log("一定执行的代码")
})
}
</script>
</body>
</html>
params是一个{}对象
那么也可以
var data={
xxx:xxx
yyy:yyy
}
然后里面
params:data 即可
例如
data:image/s3,"s3://crabby-images/230a6/230a6ce653583633abe770f829148f8f952f9077" alt=""
Axios发送POST请求
data:image/s3,"s3://crabby-images/2ea66/2ea665fc2c1f92609bd8e26a72ad63d8efe5615a" alt=""
后端接收可以是单个接收 也可以是实体类
data:image/s3,"s3://crabby-images/df974/df974829b93f20b8bd3185020ad228a8063504e3" alt=""
用AXIOS发送Post请求 application/json
后端接收
data:image/s3,"s3://crabby-images/f5028/f5028ac2d920afa0ee9a713f1e81bfc64d3d23b5" alt=""
这个请求会发送预请求 实际上是两个请求
data:image/s3,"s3://crabby-images/f46b3/f46b399929c16ebcfe106580605c61ee8f94fdf5" alt=""
预请求
data:image/s3,"s3://crabby-images/39548/39548b7ae0dfb5f819c63e96a13c68d2e3478a9e" alt=""
AXIOS也可以像ajax那样配置项的方式发送请求
下面两种方式使用POST PUT PATCH
这种方式默认Content-Type是application/json
data:image/s3,"s3://crabby-images/44510/445103ee15cc33f3058a1e9a52d3df7c0100e446" alt=""
data:image/s3,"s3://crabby-images/7cbf9/7cbf9b0956aafb809601c77f16dd3fcbb989503d" alt=""
AXIOS的返回值
data:image/s3,"s3://crabby-images/faebf/faebfbf47547751f409be52244958dd3d5358ace" alt=""
AXIOS的拦截器
拦截器分两种,分别是
请求拦截器:在发起请求之前执行,可以对请求内容做修改,比如增加参数,设置请求头等等
应答拦截器(相应拦截器):服务器返回结果,AXIOS的then之前先执行,可以对应答内容做处理
请求拦截器写法
axios.interceptors.request.use(function(xxx){ 记得return xxx},function(yyy) {如果错误做错误处理});
data:image/s3,"s3://crabby-images/72dec/72dec3770f0aeaefb5c4760230130fc3a15d2ead" alt=""
data:image/s3,"s3://crabby-images/dfff0/dfff09888af4fe792b6d892d0489360fc0a0beda" alt=""
响应拦截器
AXIOS进行全局默认配置
data:image/s3,"s3://crabby-images/66907/669071cbd55c1e0e99d6d8f87679f629bb0f3d85" alt=""