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 相关文章推荐
FireFox与IE 下js兼容触发click事件的代码
Nov 20 Javascript
JS生成随机字符串的多种方法
Jun 10 Javascript
jquery实现Ctrl+Enter提交表单的方法
Jul 21 Javascript
JavaScript简单判断复选框是否选中及取出值的方法
Aug 13 Javascript
javascript弹出窗口实现代码
Nov 12 Javascript
完美解决js传递参数中加号和&amp;号自动改变的方法
Oct 11 Javascript
JS实现超简单的汉字转拼音功能示例
Dec 22 Javascript
基于js中this和event 的区别(详解)
Oct 24 Javascript
微信小程序中添加客服按钮contact-button功能
Apr 27 Javascript
vue.js添加一些触摸事件以及安装fastclick的实例
Aug 28 Javascript
vue项目使用axios发送请求让ajax请求头部携带cookie的方法
Sep 26 Javascript
Element Tooltip 文字提示的使用示例
Jul 26 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+jQuery翻板抽奖功能实现
2015/10/19 PHP
ThinkPHP开发--使用七牛云储存
2017/09/14 PHP
Javascript中 关于prototype属性实现继承的原理图
2013/04/16 Javascript
js判断屏幕分辨率的代码
2013/07/16 Javascript
Jquery 动态循环输出表格具体方法
2013/11/23 Javascript
Jquery ajaxStart()与ajaxStop()方法(实例讲解)
2013/12/18 Javascript
jquery删除提示框弹出是否删除对话框
2014/01/07 Javascript
JavaScript实现将数组中所有元素连接成一个字符串的方法
2015/04/06 Javascript
JavaScript程序中的流程控制语句用法总结
2016/05/23 Javascript
JS实现添加,替换,删除节点元素的方法
2016/06/30 Javascript
Javascript 链式作用域详细介绍
2017/02/23 Javascript
Node.JS中事件轮询(Event Loop)的解析
2017/02/25 Javascript
Swiper实现轮播图效果
2017/07/03 Javascript
JavaScript中var、let、const区别浅析
2018/06/24 Javascript
jQuery中each遍历的三种方法实例分析
2018/09/07 jQuery
浅谈JavaScript面向对象--继承
2019/03/20 Javascript
Python中decorator使用实例
2015/04/14 Python
Python每天必学之bytes字节
2016/01/28 Python
详解Python中表达式i += x与i = i + x是否等价
2017/02/08 Python
python批量修改文件编码格式的方法
2018/05/31 Python
利用python-docx模块写批量生日邀请函
2019/08/26 Python
韩国爱茉莉太平洋化妆品美国站:Amore Pacific US
2016/10/28 全球购物
VIVOBAREFOOT赤脚鞋:让您的脚做自然的事情
2017/06/01 全球购物
MADE荷兰:提供原创设计师家具
2018/04/03 全球购物
澳大利亚音乐商店:Bava’s Music City
2019/05/05 全球购物
日本动漫周边服饰销售网站:Atsuko
2019/12/16 全球购物
Pharmacy Online中文直邮网站:澳洲大型药房
2020/06/27 全球购物
如何用JQuery进行表单验证
2013/05/29 面试题
社团活动总结模板
2014/06/30 职场文书
2014广电局实施党的群众路线教育实践活动方案思想汇报
2014/09/22 职场文书
会计求职自荐信
2015/03/26 职场文书
谢师宴家长致辞
2015/07/27 职场文书
2016大学生形势与政策心得体会
2016/01/12 职场文书
python可视化之颜色映射详解
2021/09/15 Python
JS的深浅复制详细
2021/10/16 Javascript
Redis 限流器
2022/05/15 Redis