es7学习教程之fetch解决异步嵌套问题的方法示例


Posted in Javascript onJuly 21, 2017

本文主要给大家介绍的是关于fetch API解决异步嵌套问题,下面话不多说,来一起看看详细的介绍:

我们之前学习了async和await,知道他是为了解决浏览器异步获取的的!但是我们用fetch api的话方法会更加的简单

async和await解决异步嵌套

function ajax(url){

   return new Promise(function(reslove,reject){
    let xmlHttp=new XMLHttpRequest();
    xmlHttp.open("get",url,true);
    xmlHttp.onreadystatechange=function(){
     if(xmlHttp.readyState==4&&xmlHttp.status==200){
      let data=JSON.parse(xmlHttp.responseText);
      reslove(data);
     }
    }
    xmlHttp.send(null);
   })
  }
  let uldom=document.getElementById("students");
  let url="http://192.168.0.57:8000/students.json";
  async function main(){
  let data=await ajax(url);
  
  let students=data;
  let html="";
  for(let i=0,l=students.length;i<l;i++){
   let name=students[i].name;
   let age=students[i].age;
   html+=`
   <li>姓名${name},年龄${age}</li>
   `
  }
  uldom.innerHTML=html;
  }
  main();

我们需要创建Promise函数来进行操作,如果我们用fetch解决的话,会更加的方便!

let uldom=document.getElementById("students");
  let url="http://192.168.0.57:8000/students.json";
  function main(){
   fetch(url).then(respone=>{
   return respone.json();
  }).then(data=>{
   let students=data;
   let html="";
   for(let i=0,l=students.length;i<l;i++){
    let name=students[i].name;
    let age=students[i].age;
    html+=`
    <li>姓名${name},年龄${age}</li>
    `
   }
   uldom.innerHTML=html;
  });
   
  }
  main();

不用创建Promise,直接调用then()是不是比上边更加的简单!

async、await结合fetch处理异步

let uldom=document.getElementById("students");
 let url="http://192.168.0.57:8000/students.json"; 
 async function main(){
  let respone = await fetch(url);
  let student = await respone.json();
  let html="";
  for (let i=0,l=students.length;i<l;i++){
   let name=students[i].name;
   let age=students[i].age;
   html+=`
   <li>姓名${name},年龄${age}</li>
   `
  }
  uldom.innerHTML=html;
  }
 main()

感觉是不是很简单!比上一种方法更加的简单。

总结

以上就是这篇文章的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
jQuery 遍历- 关于closest() 的方法介绍以及与parents()的方法区别分析
Apr 26 Javascript
利用函数的惰性载入提高javascript代码执行效率
May 05 Javascript
JS简单实现String转Date的方法
Mar 02 Javascript
canvas仿iwatch时钟效果
Mar 06 Javascript
vue-infinite-loading2.0 中文文档详解
Apr 08 Javascript
vue 实现数字滚动增加效果的实例代码
Jul 06 Javascript
图文讲解vue的v-if使用方法
Feb 11 Javascript
TypeScript中使用getElementXXX()的示例代码
Sep 12 Javascript
解决layui中onchange失效以及form动态渲染失效的问题
Sep 27 Javascript
JS实现打砖块游戏
Feb 14 Javascript
vue实践---根据不同环境,自动转换请求的url地址操作
Sep 21 Javascript
javascript代码实现简易计算器
Jan 25 Javascript
js图片轮播插件的封装
Jul 21 #Javascript
Javascript es7中比较实用的两个方法示例
Jul 21 #Javascript
AngularJS中使用three.js的实例详解
Jul 21 #Javascript
Axios学习笔记之使用方法教程
Jul 21 #Javascript
Vue学习笔记进阶篇之函数化组件解析
Jul 21 #Javascript
用javascript获取任意颜色的更亮或更暗颜色值示例代码
Jul 21 #Javascript
基于JavaScript实现数码时钟效果
Mar 30 #Javascript
You might like
编写Smarty插件在模板中直接加载数据的详细介绍
2013/06/26 PHP
php使用CURL不依赖COOKIEJAR获取COOKIE的方法
2015/06/17 PHP
详解PHP序列化反序列化的方法
2015/10/27 PHP
php的laravel框架快速集成微信登录的方法
2016/12/12 PHP
Thinkphp 中 distinct 的用法解析
2016/12/14 PHP
JS前端框架关于重构的失败经验分享
2013/03/17 Javascript
js下拉框二级关联菜单效果代码具体实现
2013/08/03 Javascript
jquery改变tr背景色的示例代码
2013/12/28 Javascript
JQuery异步加载无限下拉框级联功能实现示例
2014/02/19 Javascript
angularjs指令中的compile与link函数详解
2014/12/06 Javascript
JQuery中属性过滤选择器用法实例分析
2015/05/18 Javascript
在JavaScript中使用开平方根的sqrt()方法
2015/06/15 Javascript
js计算文本框输入的字符数
2015/10/23 Javascript
JavaScript保留关键字汇总
2015/12/01 Javascript
jquery获取form表单input元素值的简单实例
2016/05/30 Javascript
AngularJS教程 ng-style 指令简单示例
2016/08/03 Javascript
jQuery插件echarts实现的单折线图效果示例【附demo源码下载】
2017/03/04 Javascript
js构建二叉树进行数值数组的去重与优化详解
2018/03/26 Javascript
[01:12:40]DOTA2-DPC中国联赛 正赛 DLG vs XG BO3 第三场 1月25日
2021/03/11 DOTA
在Python的框架中为MySQL实现restful接口的教程
2015/04/08 Python
Python装饰器用法实例总结
2018/05/26 Python
Python定义二叉树及4种遍历方法实例详解
2018/07/05 Python
Python数据报表之Excel操作模块用法分析
2019/03/11 Python
Python 转换RGB颜色值的示例代码
2019/10/13 Python
python基于event实现线程间通信控制
2020/01/13 Python
使用python爬取抖音app视频的实例代码
2020/12/01 Python
在使用非全零作为空指针内部表达的机器上, NULL是如何定义
2014/11/09 面试题
商场经理竞聘演讲稿
2014/01/01 职场文书
房屋出售协议书
2014/04/10 职场文书
改革共识倡议书
2014/08/29 职场文书
新兵入伍心得体会
2014/09/04 职场文书
“九一八事变纪念日”国旗下讲话稿
2014/09/14 职场文书
监理中标通知书
2015/04/16 职场文书
小兵张嘎电影观后感
2015/06/03 职场文书
2015年学校管理工作总结
2015/07/20 职场文书
2016年大学生寒假社会实践心得体会
2015/10/09 职场文书