重学JS(十二)—— Ajax和fetch,你选哪个

Ajax 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术。
Ajax 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术。

是个前端都会用ajax,因为它原生的写法很鸡肋,所以大多会封装下,导致可能很多人不会自己写个ajax请求。

var xhr= new XMLHttpRequest(); // 新建XMLHttpRequest对象
xhr.onload= function(){ //请求完成
  console.log(this.responseText);
}
// 发送请求:
xhr.open('GET', '/user');
xhr.send();

这样一个请求就发出去了。很麻烦,发个简单请求,还得写这么多行代码。
实际开发中当然不会这么写,否则代码冗余,可读性差,用promise封装一下

function  send(url){
  return new Promise((resolve,reject) => {
     var xhr= new XMLHttpRequest(); // 新建XMLHttpRequest对象
     xhr.onload = function(){ //请求完成
        if(xhr.status === 200 )
         resolve(this.responseText);
        else
         reject(this.responseText);
     }
     // 发送请求:
     xhr.open('GET', url);
     xhr.send(); 
  })
}

之后就可以send().then()这么用了。不多说,用express生成个简单服务器试试效果。
后端代码:

router.get('/getUser', function(req, res, next) {
  res.send('success');  //这个请求返回成功
});

router.get('/getName', function(req, res, next) {
  res.status(404).send('failed');   //这个请求返回失败
});

前端代码:

send('/getUser').then(json =>{console.log(json)});  //success
send('/getName').catch(json =>{console.log(json)});  //failed

分别打印出了success和failed。
后面fetch出来了,ajax受到了前所未有的威胁,看看大家是怎么评价fetch的。

语法简洁,更加语义化
基于标准 Promise 实现,支持 async/await

唔~说的好像fetch可以直接上手似的。
先试试它能给我什么结果。

fetch('/getUser').then(response=> response.text()).then(json => console.log(json));   //success
fetch('/getName').then(response=> response.text()).then(json => console.log(json));  //failed

可以看到fetch不会因为服务器返回了404,而帮你reject。注意'getName'这个接口是靠then回调来处理的,不是catch。所以直接用fetch不行,也需要额外封装一层。
语法简洁,更加语义化。基于标准 Promise 实现,支持 async/await 以这点来说,fetch对开发库的人员是较友好的,相比ajax。

ReadableStream

fetch 将 response.body 设计成 ReadableStream。所以上面我们取返回内容的时候,是通过text()函数。因为这个设计我们不得不多进行一次转化。看看response.body是什么

fetch('/getUser').then(response=>console.log(response.body));

这个设计对读取大型文件的时候十分有用。flv.js就是用fetch请求视频数据,然后不断读取流中数据,解析,再塞到video标签,让video标签能够持续播放视频。
我们不必等待所有数据全部返回再处理,而是可以一点点地边读数据边处理数据,是不是让人很兴奋。

function fetchUrl(url){
  fetch(url).then(response => {
    var reader = response.body.getReader();
    let charsReceived = 0; //接收字符
    let num = 0;
    reader.read().then(function processText({ done, value }) {
      if (done) {
       console.log("Stream complete,received " + charsReceived+" read " + num);
       return;
      }
      charsReceived += value.length;
      num++;
      return reader.read().then(processText);  //循环读直到全部读完为止
    })  
});
}
fetchUrl('/getUser');
//Stream complete,received 7 read 1

success ,是7个字符。读了一次。读一次是因为服务器是一次性的把success吐出来了。
服务器增加条路由

router.get('/getFile', function(req, res, next) {
  let stream = fs.createReadStream(__dirname + '/test.txt');//创造可读流
  stream.pipe(res);//将可读流写入response
});

再试试

fetchUrl('/getFile');  //Stream complete,received 436084 read 7

很完美。将test.txt文件一小段一小段地发送到客户端,减小了服务器的内存压力,同时也提高了前端的响应速度。

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,594评论 18 139
  • 原文链接:https://www.cnblogs.com/libin-1/p/6853677.html 无论用Ja...
    九毛Evaline阅读 9,144评论 0 7
  • 在这篇文章中,我们将介绍一些用于AJAX调用的最好的JS库,包括jQuery,Axios和Fetch。欢迎查看代码...
    天as痕阅读 314评论 1 3
  • 本文详细介绍了 XMLHttpRequest 相关知识,涉及内容: AJAX、XMLHTTP、XMLHttpReq...
    semlinker阅读 13,602评论 2 18
  • 近来读诗僧王梵志,他的语言浅近,多用村言俚语,劝诫世人。在他的《诗一首》中有这样一句“丈夫无伎艺,虚沾一世人”,我...
    青若潇潇阅读 278评论 0 1