XMLHttpRequest 是一个设计粗糙的 API,配置和调用方式非常混乱, 而且基于事件的异步模型写起来不友好,容易回调地狱。
fetch缺点是
兼容性不好 https://github.com/camsong/fetch-ie8
Fetch 请求默认是不带 cookie 的,需要设置 fetch(url, {credentials: ‘include’})
get
fetch("url").then(res=>res.json()).then(res=>{
console.log(res)})
fetch("url").then(res=>res.text()).then(res=>{
console.log(res)})
post
fetch("url",{
method:'post',
headers: {
"Content‐Type": "application/x‐www‐form‐urlencoded"
},
body: "name=kerwin&age=100"
}).then(res=>res.json()).then(res=>{
console.log(res)});
fetch("/users",{
method:'post',
headers: {
"Content‐Type": "application/json"
},
body: JSON.stringify({
name:"shirley",
age:100
})
}).then(res=>res.json()).then(res=>{
console.log(res)});
例子:
<div id="box">
<button @click="handleFetch">fetch</button>
<ul>
<li v-for="item in itemList" :key="item.id">
{
{
item.nm}}
<img :src="handleImg(item.img)">
</li>
</ul>
</div>
new Vue({
el : '#box',
data :{
itemList : []
},
methods: {
handleFetch(){
fetch('./json/maoyan.json')
.then(res=>res.json())
.then(res=>{
// console.log(res)
this.itemList = res.coming
})
},
handleImg(path){
return path.replace('w.h','')+"@1l_1e_1c_128w_180h"
}
}
})
基于promise封装
methods: {
handleClick(){
axios.get('./json/maoyan.json').then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
})
}
}
get
methods: {
handleClick(){
axios.get('./json/maoyan.json',{
params:{
name: 'shirley',
age : 20
}
}).then(res=>{
console.log(res)
}).catch(err=>{
console.log(err)
})
}
}
post
post不需要写params
methods: {
handleClick(){
axios.post('/api/login',{
username:'shirley',
password: '123'
}).then(res=>{
console.log(res.data)
}).catch(err=>{
console.log(err)
})
}
}
跨域的三种方式
1.需要靠后端设置字段 , cors跨域解决方案
网站中 Response Headers 中 有 Access-Control- Allow-Origin : * 代表允许跨域
2.如果后端不设置 ,需要靠前端来反向代理
3.jsonp接口 ,前后端协作 ,axios不支持jsonp
axios请求数据 ,传请求头Headers
卖座前后端的数据通过字段 X-Client-Info 和X-Host
以前jquery的时候,可以直接传header , 只要把请求字段带来就可以。
$.ajax({
headers:{
},data:{
},type:''})
handleClick(){
axios({
url:'https://.......',
methods : 'get/post'
headers :{
'X-Client-Info' :'{"a":"3000","ch":"1002"}', //传过来的是对象不行,要改成字符串
'X-Host' : 'mall.film-ticket.film.list'
}
}).then(res=>{
console.log(res.data)
})
}
jquery支持jsonp
axios不支持jsonp