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 相关文章推荐
JavaScript 事件对象的实现
Jul 13 Javascript
提升你网站水平的jQuery插件集合推荐
Apr 19 Javascript
JS实现QQ图片一闪一闪的效果小例子
Jul 31 Javascript
jquery-syntax动态语法着色示例代码
May 14 Javascript
Jquery幻灯片特效代码分享--鼠标点击按钮时切换(1)
Aug 15 Javascript
jQuery实现Tab菜单滚动切换的方法
Sep 21 Javascript
jQuery的实例及必知重要的jQuery选择器详解
May 20 Javascript
js实现无缝循环滚动
Jun 23 Javascript
angularjs过滤器--filter与ng-repeat配合有奇效
Apr 20 Javascript
一个因@click.stop引发的bug的解决
Jan 08 Javascript
JS实现的进制转换,浮点数相加,数字判断操作示例
Nov 09 Javascript
JS实现点星星消除小游戏
Mar 24 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技术
2007/01/04 PHP
PHP手机号码归属地查询代码(API接口/mysql)
2012/09/04 PHP
CodeIgniter启用缓存和清除缓存的方法
2014/06/12 PHP
PHP实现重载的常用方法实例详解
2017/10/18 PHP
var与Javascript变量隐式声明
2009/09/17 Javascript
js 操作select和option常用代码整理
2012/12/13 Javascript
javascript限制文本框只允许输入数字(曾经与现在的方法对比)
2013/01/18 Javascript
jquery表格内容筛选实现思路及代码
2013/04/16 Javascript
div拖拽插件——JQ.MoveBox.js(自制JQ插件)
2013/05/17 Javascript
JS实现至少包含字母、大小写数字、字符的密码等级的两种方法
2015/02/03 Javascript
JavaScript的Backbone.js框架环境搭建及Hellow world示例
2016/05/07 Javascript
Vue2组件tree实现无限级树形菜单
2017/03/29 Javascript
nodejs入门教程三:调用内部和外部方法示例
2017/04/24 NodeJs
bootstrap table sum总数量统计实现方法
2017/10/29 Javascript
jQuery实现滚动效果
2017/11/17 jQuery
JS实现图片居中悬浮效果
2017/12/25 Javascript
JavaScript格式化json和xml的方法示例
2019/01/22 Javascript
搭建一个nodejs脚手架的方法步骤
2019/06/28 NodeJs
JS前端广告拦截实现原理解析
2020/02/17 Javascript
ES2020让代码更优美的运算符 (?.) (??)
2021/01/04 Javascript
[47:38]Optic vs VGJ.S 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
在Python的web框架中编写创建日志的程序的教程
2015/04/30 Python
Python常见工厂函数用法示例
2018/03/21 Python
python购物车程序简单代码
2018/04/18 Python
Django 实现admin后台显示图片缩略图的例子
2019/07/28 Python
Python3操作Excel文件(读写)的简单实例
2019/09/02 Python
解决运行出现'dict' object has no attribute 'has_key'问题
2020/07/15 Python
html5教程调用绘图api画简单的圆形代码分享
2013/12/04 HTML / CSS
伦敦新晋轻奢耳饰潮牌:Tada & Toy
2020/05/25 全球购物
学前教育毕业生自荐信范文
2013/12/24 职场文书
简单租房协议书
2014/04/09 职场文书
《风筝》教学反思
2014/04/10 职场文书
给市场的环保建议书
2014/05/14 职场文书
幼儿教师年度个人总结
2015/02/05 职场文书
少先队工作总结2015
2015/05/13 职场文书
2015年小学实验室工作总结
2015/07/28 职场文书