fetch 的使用

来源:互联网 发布:linux 黑客技术 编辑:程序博客网 时间:2024/06/08 09:08

现在应该很少有人用原生的JS内置XMLHttpRequest对象写异步调用了,仍然用的比较多的应该是Jquery的ajax方法,例如:

$.ajax({   type: 'get',   url: location.herf,   success: function(data){       console.log(data);   }})

最近写一个demo用到了fetch API,顿时觉得比ajax好用n倍,遂记录之。

fetch 介绍

fetch API 来源于 Promise ,可参见:Promise;

fetch的API 也可以参见:fetch;

fetch()方法调用两个参数:

fetch(input, init)

其中:
input
* 定义要获取的资源。这可能是:一个 USVString 字符串,包含要获取资源的 URL。一些浏览器会接受 blob: 和 data:
* 作为 schemes.一个 Request 对象。

input直白来说等于ajax中传入的url;

fetch()另一个参数 init可以配置其他请求相关参数,相当于ajax里的type,这个参数是可选的,包括:

method: 请求使用的方法,如 GET、POST.
headers: 请求的头信息,形式为 Headers 对象或 ByteString。
body: 请求的 body 信息,可能是一个 Blob、BufferSource、FormData、URLSearchParams 或者 USVString 对象。(如果是 GET 或 HEAD 方法,则不能包含 body 信息)
mode: 请求的模式,如 cors、 no-cors 或者 same-origin。
credentials: 请求的 credentials,如 omit、same-origin 或者 include。
cache: 请求的 cache 模式: default, no-store, reload, no-cache, force-cache, or only-if-cached。

fetch()的success callback 是用 .then()完成的,实际上按照我的理解,fetch()就是一个Promise对象的实例,Promise对象实例如下:

new Promise(    /* executor */    function(resolve, reject) {...});
var promise = new Promise(function(resolve, reject) {  if (/* 异步操作成功 */){    resolve(value);  } else {    reject(error);  }});promise.then(function(value) {  // success}, function(value) {  // failure});

所以fetch()中,通过.then()调用异步成功函数resolve,通过.catch()调用异步失败函数reject;
拼装在一起,就有:

fetch(location.herf, {    method: "get"}).then(function(response) {    return response.text()}).then(function(data) {    console.log(data)}).catch(function(e) {  console.log("Oops, error");});

这其中,第一步.then()将异步数据处理为text,如果需要json数据,只需要 :

function(response) {return response.json()}

用es6箭头函数写,就是:

fetch(url).then(res => res.json())  .then(data => console.log(data))  .catch(e => console.log("Oops, error", e));

fetch 兼容性

所有的ie都不支持fetch()方法,所以,考虑兼容性,需要对fetch()使用polyfill;
使用Fetch Polyfil来实现 fetch 功能:

npm install whatwg-fetch –save

对于ie,还要引入Promise:

npm install promise-polyfill –save-exact

考虑到跨域问题,需要使用Jsonp,那么还需要fetch-jsonp:

npm install fetch-jsonp

至此,则有:

import 'whatwg-fetch';import Promise from 'promise-polyfill';import fetchJsonp from 'fetch-jsonp';fetchJsonp('/users.jsonp')  .then(function(response) {    return response.json()  }).then(function(json) {    console.log('parsed json', json)  }).catch(function(ex) {    console.log('parsing failed', ex)  })

Ref:

  • 传统 Ajax 已死,Fetch 永生
  • 使用更优雅的异步请求API——fetch
  • MDN web docs
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 工资表税金扣多了怎么办? 装修公司不发放工程怎么办 公司不给开收入证明怎么办 装修公司不付工人工资怎么办 收入证明少500元怎么办 dnf二级输错了怎么办 如果受到法律的伤害怎么办 86岁了还怕死怎么办 风衣的腰带丢了怎么办 成为伪娘身上的毛怎么办 军官升不上去了怎么办 王者荣耀代练封号怎么办 cf淘宝代练封号怎么办 买音乐会的票过期怎么办 十年多年前被怨错拘留了怎么办 与室友关系闹僵怎么办 开庭后被告威胁我们证人怎么办 开车撞了豪车怎么办 我把人撞了全责怎么办 开车撞伤人没钱赔怎么办 开车撞伤无证驾驶人怎么办 开车把人撞伤了只买交强险怎么办 开车撞伤人赔不起怎么办 如果车撞死人了怎么办 给车撞了跑了怎么办 开车把人撞死了怎么办 开车把人蹭了怎么办 驾照被扣54分怎么办? 驾照被扣了12分怎么办 驾驶证丢失后被扣分怎么办 驾照扣了三十分怎么办 一次被扣了12分怎么办 驾照被扣35分后怎么办 我驾驶证扣了6分怎么办 c1驾照被扣6分怎么办 被扣了6分怎么办 今年扣了6分怎么办 驾照分不够扣了怎么办 被扣6分怎么办罚款15 驾照分数扣36分怎么办 驾照12分不够扣怎么办