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 相关文章推荐
js实现倒计时时钟的示例代码
Dec 17 Javascript
jquery map方法使用示例
Apr 23 Javascript
JavaScript DOM节点添加示例
Jul 16 Javascript
js中this的用法实例分析
Jan 10 Javascript
jQuery插件Elastislide实现响应式的焦点图无缝滚动切换特效
Apr 12 Javascript
jquery+CSS实现的多级竖向展开树形TRee菜单效果
Aug 24 Javascript
js入门之Function函数的使用方法【新手必看】
Nov 22 Javascript
AngularJS的依赖注入实例分析(使用module和injector)
Jan 19 Javascript
js实现抽奖效果
Mar 27 Javascript
详解vue-cli快速构建项目以及引入bootstrap、jq
May 26 Javascript
vue树形结构获取键值的方法示例
Jun 21 Javascript
echarts实现折线图的拖拽效果
Dec 19 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
php中常见的sql攻击正则表达式汇总
2014/11/06 PHP
Joomla语言翻译类Jtext用法分析
2016/05/05 PHP
深入浅析PHP无限极分类的案例教程
2016/05/09 PHP
js tab 选项卡
2009/04/26 Javascript
屏蔽网页右键复制和ctrl+c复制的js代码
2013/01/04 Javascript
jquery设置控件位置的方法
2013/08/21 Javascript
js 赋值包含单引号双引号问题的解决方法
2014/02/26 Javascript
jquery中one()方法的用法实例
2015/01/16 Javascript
在JavaScript中如何解决用execCommand(
2015/10/19 Javascript
基于JavaScript如何实现ajax调用后台定义的方法
2015/12/29 Javascript
JavaScript数据结构与算法之链表
2016/01/29 Javascript
Bootstrap编写一个兼容主流浏览器的受众门户式风格页面
2016/07/01 Javascript
js创建对象几种方式的优缺点对比
2016/09/28 Javascript
jquery 追加元素append、prepend、before、after用法与区别分析
2016/12/02 Javascript
vuejs指令详解
2017/02/07 Javascript
Javascript实现base64的加密解密方法示例
2017/06/27 Javascript
vue父组件通过props如何向子组件传递方法详解
2017/08/16 Javascript
使用vue-router为每个路由配置各自的title
2018/07/30 Javascript
微信小程序自定义组件封装及父子间组件传值的方法
2018/08/28 Javascript
[43:24]2018DOTA2亚洲邀请赛3月29日 小组赛A组 LGD VS Liquid
2018/03/30 DOTA
python实现基本进制转换的方法
2015/07/11 Python
Python for Informatics 第11章之正则表达式(四)
2016/04/21 Python
Django返回json数据用法示例
2016/09/18 Python
Windows下anaconda安装第三方包的方法小结(tensorflow、gensim为例)
2018/04/05 Python
python3.6下Numpy库下载与安装图文教程
2019/04/02 Python
pycharm-professional-2020.1下载与激活的教程
2020/09/21 Python
日本最大的眼镜购物网站:Oh My Glasses
2016/11/13 全球购物
adidas马来西亚官网:adidas MY
2020/09/12 全球购物
优秀员工个人的自我评价
2013/11/29 职场文书
中学家长会邀请函
2014/01/17 职场文书
优秀员工评语
2014/02/10 职场文书
国家机关领导干部民主生活会对照检查材料思想汇报
2014/09/17 职场文书
毕业实习自我鉴定范文2014
2014/09/26 职场文书
材料员岗位职责
2015/02/10 职场文书
2016年中秋节寄语大全
2015/12/07 职场文书
2016年社区六一儿童节活动总结
2016/04/06 职场文书