The await operator is used to wait for a promise to settle. It pauses the execution of an async function until the promise is either fulfilled or rejected. const API_URL = "https://starwars.egghead.training/"; const output = document.getElementB…
本文引自: https://www.jianshu.com/p/435a8b8cc7d3 async function fn(){ //表示异步,这个函数里面有异步任务 let result = await xxx //表示后面结果需要等待数据读取完后执行 } async特点: await只能放到async函数中 相比genrator语义化更强 await后面可以是promise对象,也可以是数字.字符串.布尔 async函数返回的是一个promise对象 只要await语句后面Promise状…
/* 原则: 执行完当前promise, 会把紧挨着的then放入microtask队尾, 链后面的第二个then暂不处理分析, */ 一. new Promise((resolve, reject) => { console.log("promise1") resolve() }).then( () => { console.log("then11") new Promise((resolve, reject) => { console.log(…
es6 一经推出,Promise 就一直被大家所关注.那么,为什么 Promise 会被大家这样关注呢?答案很简单,Promise 优化了回调函数的用法,让原本需要纵向一层一层嵌套的回调函数实现了横向的调用,也就是链式调用. 我们先来看下面的代码: function getData(){ setTimeout(()=>{ var name = "zhangsan"; }, 1000) } getData(); 在上面的代码中,我们模拟了一个异步时间,一秒后输出 name = &q…
async function 声明用于定义一个返回 AsyncFunction 对象的异步函数 await  操作符用于等待一个Promise 对象.它只能在异步函数 async function 中使用 语法: [return_value] = await expression; * 属于ES7语法,目前不被浏览器支持 使用注意: 1. await 必须在 async 声明的函数体中才能使用 2. await 后面只能是Promise对象,如果等待的不是 Promise 对象,则返回该值本身…
这篇有点长,不过干货挺多,既分析promise的原理,也包含一些最佳实践,亮点在最后:) 还记得上一节讲回调函数的时候,第一件事就提到了异步函数不能用return返回值,其原因就是在return语句执行的时候异步代码还没有执行完毕,所以return的值不是期望的运算结果. Promise却恰恰要回过头来重新利用这个return语句,只不过不是返回最终运算值,而是返回一个对象,promise对象,用它来帮你进行异步流程管理. 先举个例子帮助理解.Promise对象可以想象成是工厂生产线上的一个工人…
JavaScript:学习笔记(9)——Promise对象 引入Promise Primose是异步编程的一种解决方案,比传统的解决方案回调函数和事件更加合理和强大.如下面为基于回调函数的Ajax操作: request.onreadystatechange = function () { if (request.readyState === 4) { if (request.status === 200) { return success(request.responseText); } els…
Promise 出现的原因 在 Promise 出现以前,我们处理一个异步网络请求,大概是这样: // 请求 代表 一个异步网络调用. // 请求结果 代表网络请求的响应. 请求1(function(请求结果1){ 处理请求结果1 }) 看起来还不错.但是,需求变化了,我们需要根据第一个网络请求的结果,再去执行第二个网络请求,代码大概如下: 请求1(function(请求结果1){ 请求2(function(请求结果2){ 处理请求结果2 }) }) 看起来也不复杂.但是..需求是永无止境的,于…
Promise对象 //1开始 function fna(){ console.log('1开始'); var p = new Promise(function(resolve, reject){ //做一些异步操作 setTimeout(function(){ console.log('1完毕!'); resolve('进行2');//完成(Rejected) }, 6000); // setTimeout(function(){ // console.log('1失败!'); // reje…
1.函数调用的四种方式 第三种:构造函数调用 如果构造函数调用在圆括号内包含一组实参列表,先计算这些实参表达式,然后传入函数内.这和函数调用和方法调用是一致的.但如果构造函数没有形参,JavaScript构造函数调用的语法是允许省略实参列表和圆括号的. 如: var o=new Object(); //->等价于 var o=new Object;   第四种:使用call()与apply()间接调用(放在后面详细说明)   2.函数的实参与形参——可选形参 先看一个例子: function g…