vue项⽬中使⽤fetch的实现⽅法
fetch的由来和定义
fetch的由来
众所周知,传统 Ajax (指 XMLHttpRequest)是最早出现的发送异步请求技术,其核⼼是使⽤XMLHttpRequest对象。但是它也存在⼀些令⼈头疼的问题:XHR 是⼀个设计粗糙的 API,不符合关注分离的原则;配置和调⽤⽅式⾮常混乱,⽽且基于事件的异步模型写起来也没有现代的 Promise,generator/yield,async/await 友好。⽽Fetch 的出现就是为了解决 XHR 存在的问题。
fetch的定义和使⽤
MDN中的描述:
Fetch API 提供了⼀个获取资源的接⼝(包括跨域请求)。任何使⽤过的⼈都能轻松上⼿,但新的API提供了更强⼤和灵活的功能集。but 因为凄惨的兼容性,让这个东东⽤起来⽐较困难。那我可以⾃⼰封装⼀下,对于不⽀持fetch的浏览器便使⽤ajax 代替(见下⽂)。
Fetch 的核⼼在于对 HTTP 接⼝的抽象,包括,,,,以及⽤于初始化异步请求的。其中,global fetch⽅法的语法定义:fetch(input[, init]);
input:定义要获取的资源。可以是⼀个资源的 URL 字符串,也可以是⼀个 Request 对象。
init:可选,⼀个配置项对象,包括所有对请求的设置。包括:method,headers,body,mode,credentials等返回值:Promise
切记⼀点:Fetch是基于promise设计的,它不是ajax的进⼀步封装,⽽是原⽣js API,没有使⽤XMLHttpRequest对象。
fetch的优点和缺点
优点:
1. 语法简洁,更加语义化
2. 基于标准 Promise 实现,⽀持 async/await
3. 同构⽅便,更加底层,提供的API丰富(request, response, body , headers)5. 脱离了XHR,是ES规范⾥新的实现⽅式
缺点:
1. fetch只对⽹络请求报错,对400,500都当做成功的请求,服务器返回 400,500 错误码时并不会 reject。
2. fetch默认不会带cookie,需要添加配置项: credentials: 'include'。
3. fetch不⽀持abort,不⽀持超时控制,造成了流量的浪费。
4. fetch没有办法原⽣监测请求的进度,⽽XHR可以
补充知识点:
Fetch的mode配置项有3个取值:
same-origin:该模式是不允许跨域的,它需要遵守同源策略;
cors: 该模式⽀持跨域请求,顾名思义它是以CORS的形式跨域;
no-cors: 该模式⽤于跨域请求但是服务器不带CORS响应头,也就是服务端不⽀持CORS;⽬前,针对跨域请求,cors模式是常见的实现。
vue项⽬中完美封装fetch
话不多少,直接附上代码。
env.js⽂件,如下:
/**
* baseUrl: 域名地址
* routerMode: 路由模式
*/
let baseUrl = '';
let routerMode = 'history';
if (v.NODE_ENV == 'development') {
baseUrl = 'localhost:3000';
}else{
baseUrl = 'xxxx这⾥是线上地址xxx';
}
export { baseUrl, routerMode }
fetch.js⽂件,如下:
import { baseUrl } from './env'
export default async(url = '', data = {}, type = 'GET', method = 'fetch') => {
type = UpperCase();
url = baseUrl + url;
// 此处规定get请求的参数使⽤时放在data中,如同post请求
if (type == 'GET') {
let dataStr = '';
Object.keys(data).forEach(key => {
dataStr += key + '=' + data[key] + '&';
})
if (dataStr !== '') {
dataStr = dataStr.substr(0, dataStr.lastIndexOf('&'));
url = url + '?' + dataStr;
}
}
// 对于⽀持fetch⽅法的浏览器,处理如下:
if (window.fetch && method == 'fetch') {
let requestConfig = {
/
/ fetch默认不会带cookie,需要添加配置项credentials允许携带cookie
credentials: 'include',
method: type,
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json'
},
mode: "cors", // 以CORS的形式跨域
cache: "force-cache"
fetch最佳用法}
if (type == 'POST') {
Object.defineProperty(requestConfig, 'body', {
value: JSON.stringify(data)
})
}
try {
const response = await fetch(url, requestConfig);
const responseJson = await response.json();
return responseJson
} catch (error) {
throw new Error(error)
}
} else { // 对于不⽀持fetch的浏览器,便⾃动使⽤ ajax + promise
return new Promise((resolve, reject) => {
let requestObj;
if (window.XMLHttpRequest) {
requestObj = new XMLHttpRequest();
} else {
requestObj = new ActiveXObject; // 兼容IE
}
let sendData = '';
if (type == 'POST') {
sendData = JSON.stringify(data);
}
requestObj.open(type, url, true);
requestObj.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); requestObj.send(sendData);
if (adyState == 4) {
if (requestObj.status == 200) {
let obj = sponse
if (typeof obj !== 'object') {
obj = JSON.parse(obj);
}
resolve(obj)
} else {
reject(requestObj)
}
}
}
})
}
}
以上代码,亲测有效。Over, thanks !希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论