Fetch获取数据简单例子

说到Fetch不得不提XMLHttpRequest 对象,我们经常在ajax中使用到该对象。由于XMLHttpRequest的配置和调用的方式并不是很友好,且基于事件的异步模型写起来没有现代的Promise、async/await友好,因此Fetch就应运而生了。下面我们来使用Fetch获取百度热歌榜前20名歌曲信息:

第一次尝试:

  var hotMusicListUrl = "http://tingapi.ting.baidu.com/v1/restserver/ting?type=2&size=20&offset=0&method=baidu.ting.billboard.billList",
//百度的官方api接口
    proxyUrl = "https://bird.ioliu.cn/v1/?url=";
//为了避免跨域,因此使用了JsonBird工具
  var url = proxyUrl + hotMusicListUrl;
  fetch(url).then(response =>  console.log("成功",response))
            .catch(error => console.log("刚开始就出错了,,,,", error)
  )

运行后:

image.png

第二次尝试:

这貌似不是我们想获取的数据,因此需要修改下:

  var hotMusicListUrl = "http://tingapi.ting.baidu.com/v1/restserver/ting?type=2&size=20&offset=0&method=baidu.ting.billboard.billList",
    proxyUrl = "https://bird.ioliu.cn/v1/?url=";
  var url = proxyUrl + hotMusicListUrl;
  fetch(url).then(response =>  console.log("成功",response.json()))
            .catch(error => console.log("刚开始就出错了,,,,", error)
  )
image.png

第三次尝试:

上面使用了response.json()。我们看到有[[PromiseValue]]里的song_list是我们想要的数据,但是我们直接无法拿到它,因此还需要修改下

  var hotMusicListUrl = "http://tingapi.ting.baidu.com/v1/restserver/ting?type=2&size=20&offset=0&method=baidu.ting.billboard.billList",
    proxyUrl = "https://bird.ioliu.cn/v1/?url=";
  var url = proxyUrl + hotMusicListUrl;
  fetch(url).then(response => { console.log("快成功啦") ; response.json().then(data => console.log(data) ).catch(error => console.log("煮熟的鸟飞了",error))})
            .catch(error => console.log("刚开始就出错了,,,,", error)
  )

上面我们使用了response.json().then(data => console.log(data)) 才拿到数据

image.png

第四次尝试:

当然这里也可以使用 await/async方法:

  var hotMusicListUrl = "http://tingapi.ting.baidu.com/v1/restserver/ting?type=2&size=20&offset=0&method=baidu.ting.billboard.billList",
    proxyUrl = "https://bird.ioliu.cn/v1/?url=";
  var url = proxyUrl + hotMusicListUrl;
  var getResponse = async function () {
    try {
      console.log("马上执行fetch");
      let response = await fetch(url);
      let data = await response.json();
      console.log("得到结果啦");
      console.log(data);
    } catch (error) {
      console.log("出错了。。。", error);
    }
  }
  getResponse();

Fetch常见坑及不足之处:

1、Fetch请求默认不带cookie,需要设置fetch(url, {credentials: 'include'})
2、服务器返回400 或500错误码时,不会reject,只有网络错误等这些导致请求不能完成时才会reject;
3、Fetch没有 Deferred;
4、Fetch没有获取状态方法:isRejected,isResolved;
5、Fetch不能中断,没有 abort、terminate、onTimeout 或 cancel 方法;
6、Fetch缺少其它一些方法:always,progress,finally
7、Fetch响应中有中文时有时会乱码,因此注意后端数据的编码格式

乱码举例:

  var  proxyUrl = "https://bird.ioliu.cn/v1/?url=";
  var getResponse = async function () {
    try {
      console.log("马上执行fetch");
      let response = await fetch(proxyUrl+"https://sp0.baidu.com/5a1Fazu8AA54nxGko9WTAnF6hhy/su?wd=baidu");
      let data = await response.json();
      console.log("得到结果啦");
      console.log(data);
    } catch (error) {
      console.log("出错了。。。", error);
    }
  }
  getResponse();

image.png

以上具体可详见: 传统 Ajax 已死,Fetch 永生 及解决方案可详见Fetch进阶指南

其它资料推荐

1、 你不需要jQuery(三):新AJAX方法fetch() 这篇文章里还介绍了用fetch执行表单数据提交
2、 传统 Ajax 已死,Fetch 永生

*本文版权归本人即简书笔名:该账户已被查封 所有,如需转载请注明出处。谢谢!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,053评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,527评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,779评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,685评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,699评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,609评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,989评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,654评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,890评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,634评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,716评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,394评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,976评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,950评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,191评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,849评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,458评论 2 342

推荐阅读更多精彩内容