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中的对象创建 实例附注释
Feb 08 Javascript
JS实现浏览器状态栏文字闪烁效果的方法
Oct 27 Javascript
Jquery-1.9.1源码分析系列(十一)之DOM操作
Nov 25 Javascript
js微信扫描二维码登录网站技术原理
Dec 01 Javascript
基于Vue2实现的仿手机QQ单页面应用功能(接入聊天机器人 )
Mar 30 Javascript
JS ES6多行字符串与连接字符串的表示方法
Apr 26 Javascript
Vue 仿QQ左滑删除组件功能
Mar 12 Javascript
vue如何判断dom的class
Apr 26 Javascript
安装vue-cli的简易过程
May 22 Javascript
vue监听键盘事件的快捷方法【推荐】
Jul 11 Javascript
JavaScript类型相关的常用操作总结
Feb 14 Javascript
vue 判断两个时间插件结束时间必选大于开始时间的代码
Nov 04 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缩放图片(根据宽高的等比例缩放)实例介绍
2013/06/09 PHP
去掉destoon资讯内容页keywords关键字自带的文章标题的方法
2014/08/21 PHP
thinkPHP中create方法与令牌验证实例浅析
2015/12/08 PHP
javascript 一个自定义长度的文本自动换行的函数
2007/08/19 Javascript
基于JQuery.timer插件实现一个计时器
2010/04/25 Javascript
qTip 基于JQuery的Tooltip插件[兼容性好]
2010/09/01 Javascript
jQuery插件pagination实现分页特效
2015/04/12 Javascript
浅谈Jquery核心函数
2015/06/18 Javascript
javascript实现的字符串与十六进制表示字符串相互转换方法
2015/07/17 Javascript
举例讲解Node.js中的Writable对象
2015/07/29 Javascript
JavaScript中实现无缝滚动、分享到侧边栏实例代码
2016/04/06 Javascript
详解如何较好的使用js
2016/12/16 Javascript
JavaScript数据类型和变量_动力节点Java学院整理
2017/06/26 Javascript
小程序实现页面顶部选项卡效果
2018/11/06 Javascript
es6 symbol的实现方法示例
2019/04/02 Javascript
vue实现密码显示与隐藏按钮的自定义组件功能
2019/04/23 Javascript
Python里disconnect UDP套接字的方法
2015/04/23 Python
python连接字符串的方法小结
2015/07/13 Python
Python Django使用forms来实现评论功能
2016/08/17 Python
Python列表list解析操作示例【整数操作、字符操作、矩阵操作】
2017/07/25 Python
Django中Forms的使用代码解析
2018/02/10 Python
Python3.遍历某文件夹提取特定文件名的实例
2018/04/26 Python
对django中render()与render_to_response()的区别详解
2018/10/16 Python
Django 路由控制的实现代码
2018/11/08 Python
pyqt5 从本地选择图片 并显示在label上的实例
2019/06/13 Python
解决pycharm启动后总是不停的updating indices...indexing的问题
2019/11/27 Python
jupyter notebook清除输出方式
2020/04/10 Python
numpy矩阵数值太多不能全部显示的解决
2020/05/14 Python
移动端开发HTML5页面点击按钮后出现闪烁或黑色背景的解决办法
2018/09/19 HTML / CSS
澳大利亚宠物食品和药物在线:Jumbo Pets
2018/03/24 全球购物
土木工程个人自荐信范文
2013/11/30 职场文书
小区推广策划方案
2014/06/06 职场文书
安全生产会议制度
2015/08/06 职场文书
幼儿园亲子活动感想
2015/08/07 职场文书
党员心得体会范文2016
2016/01/23 职场文书
Golang 空map和未初始化map的注意事项说明
2021/04/29 Golang