3)嵌套函数 例 3.3.1 </head
一个Promise表示一个现在、将来或永不可能用的值. Promise 是异步编程的一种解决方案,比传统的解决方案——回调函数和事件——更合理和更强大。...这两个函数是,JavaScript引擎自带的,不用自己定义他们。...假如在.then()的函数里面不返回新的Promise,会怎样??...,分别代表fulfilled和rejected. .then()返回一个新的Promise实例,所以它可以链式调用状态响应函数可以返回新的Promise,或其他值如果返回新的Promise,那么下一级....参数,并且doSomethingElse返回一个Promise实例 错误处理 catch捕获异常 Promise会自动捕获内部异常,并交给rejected响应函数处理。
then函数回调执行完毕后才会开始下一个 then 函数,当多个 then 链式调用的时候,如果一个 then 函数放入微任务队列,没有执行完,则之后的 then 都会先忽略,继续向下寻找同步任务继续执行...首先,大家都知道 setTimeout 是宏任务,则一定在下一轮事件循环的时候才执行,则他的执行优先级最低,promise是同步任务,会先执行,promise.then() 是微任务,当遇到微任务的时候...执行到 22 行逻辑: 这里当执行到 22 行时, then的参数整体作为一个函数放入微任务队列中,因为这里还没执行,所以 555 的 then 就暂时不执行,继续下一个 333 的 then 放入微任务队列...,接下来没有同步任务了,开始执行微任务队列,当执行到 23 行的时候,这个微任务先执行 promise 同步函数,将then 444 又放入了 微任务队列,接下来没有课执行的同步任务了,则开始执行微任务队列...转载请注明来源:https://www.cnblogs.com/beileixinqing/p/16803587.html 参考文章:https://347830076.github.io/myBlog/javascript
简单分析下思路: 构造函数Promise接受一个函数resolver,可以理解为传入一个异步任务,resolver接受两个参数,一个是成功时的回调,一个是失败时的回调,这两参数和通过then传入的参数是对等的...由于then方法接受的两个参数都是可选的,而且类型也没限制,可以是函数,也可以是一个具体的值,还可以是另一个promise。...在这里,Promise.resolve(v)静态方法只是简单返回一个以v为肯定结果的promise,v可不传入,也可以是一个函数或者是一个包含then方法的对象或函数(即thenable)。...标准的Promise 可参考html5rocks的这篇文章JavaScript Promises,目前高级浏览器如Chrome、Firefox都已经内置了Promise对象,提供更多的操作接口,比如Promise.all...但Promise也只是解决了回调的深层嵌套的问题,真正简化JavaScript异步编程的还是Generator,在Node.js端,建议考虑Generator。
简单介绍一下 Promise 以及他的使用、异常处理、同步处理等等… 介绍 我们都知道 JavaScript 是一种同步编程语言,上一行出错就会影响下一行的执行,但是我们需要数据的时候总不能每次都等上一行执行完成...但是也有一个不好的地方,当我们有很多回调的时候,比如这个回调执行完需要去执行下个回调,然后接着再执行下个回调,这样就会造成层层嵌套,代码不清晰,很容易进入“回调监狱”。。。 ...,它最多需要有两个参数:Promise 的成功和失败情况的回调函数。...该函数有一个参数,即接受的最终结果(the fulfillment value)。 如果该参数不是函数,则会在内部被替换为 (x) => x,即原样返回 promise 最终结果的函数。...onRejected 可选 当 Promise 变成拒绝状态(rejected)时调用的函数。该函数有一个参数,即拒绝的原因(rejection reason)。
在学习本章节内容前,你需要先了解什么是异步编程,可以参考:JavaScript 异步编程 Promise 是一个 ECMAScript 6 提供的类,目的是更加优雅地书写复杂的异步任务。...将嵌套格式的代码变成了顺序格式的代码。...Promise 的构造函数 Promise 构造函数是 JavaScript 中用于创建 Promise 对象的内置构造函数。...Promise 构造函数接受一个函数作为参数,该函数是同步的并且会被立即执行,所以我们称之为起始函数。...Promise 构造函数返回一个 Promise 对象,该对象具有以下几个方法: then:用于处理 Promise 成功状态的回调函数。 catch:用于处理 Promise 失败状态的回调函数。
我们之前遇到的异步任务都是一次异步,如果需要多次调用异步函数呢?...将嵌套格式的代码变成了顺序格式的代码。...Promise 的使用 下面我们通过剖析这段 Promise "计时器" 代码来讲述 Promise 的使用: Promise 构造函数只有一个参数,是一个函数,这个函数在构造之后会直接被异步运行,所以我们称之为起始函数...当 Promise 被构造时,起始函数会被异步执行: 实例 new Promise(function (resolve, reject) { console.log("Run"); }); 这段程序会直接输出...resolve 和 reject 都是函数,其中调用 resolve 代表一切正常,reject 是出现异常时所调用的: 实例 new Promise(function (resolve, reject
then方法返回一个新的Promise实例,为了在Promise状态发生变化时再执行then里的函数,我们使用一个callbacks数组先把传给then的函数暂存起来,等状态改变时再调用 那么,怎么保证后一个...我们可以将传给then函数和新Promise的resolve一起push到前一个Promise的callbacks数组中,达到承前启后的效果: 承前:当前一个Promise完成后,调用其resolve变更状态...> { //封装前一个Promise成功时执行的函数 let fulfilled = () => { try { const...实例 注册完成后开始执行构造函数中的异步事件,异步完成之后依次调用callbacks数组中提前注册的回调 手写Promise.all 接收一个Promise实例的数组或具有Iterator接口的对象作为参数...因为Promise的状态只能改变一次,那么我们只需要把Promise.race中产生的Promise对象的resolve,注入到数组中的每一个Promise实例中的回调函数即可。
它们是两个函数,由JavaScript引擎提供,不用自己部署。...原因则是Promise属于JavaScript引擎内部任务,而setTimeout则是浏览器API,而引擎内部任务优先级高于浏览器API任务,所以有此结果。...async函数对 Generator 函数的改进,async 函数必定返回 Promise,我们把所有返回 Promise 的函数都可以认为是异步函数。...然后在handle函数前加上async关键词,这样就定义了一个async函数。在该函数中,利用await来等待一个Promise。...Promise优缺点 优点 缺点 解决回调 无法监测进行状态 链式调用 新建立即执行且无法取消 减少嵌套 内部错误无法抛出
setTimeout(console.log,0,p);//Promise {} setTimeout(console.log,11000,p)//Promise {函数类型的参数都会被忽略,如果只想提供onRejected参数,那么只需要将对应的参数传入undefined就好了。...它相当于一个语法糖,调用的相当于是Promise.prototype.then(null,onRejected)。...let p1 = Promise.resolve('jackson'); let p2 = p1.finally(); //Promise jackson let...console.log('bear')) .then(()=>console.log('jackson11')) .then(()=>console.log('jackson22')); 期约合成很像函数合成
首先创建一个Promise对象,根据Promise的状态来执行不同的回调函数。...then函数接收两个参数,一个onResolved(Promise 的状态为成功时候调用),一个onRejected(Promise 的状态为失败时候调用)。...为什么then函数中需要考虑Promise状态为pending的情况?当 then 方法被调用时,我们首先需要判断原始 Promise 对象的状态。...但是,如果原始 Promise 对象的状态为 pending,那么我们就需要等待原始 Promise 对象的状态发生变化,再执行相应的操作。2. 当then函数传的参数不是函数怎么办?...在调用then函数中,当Promise的状态为pending时候,会把onResolved和onRejected回调放到各自回调函数队列中,等状态改变(即在执行resolve函数/reject函数)时候
而then方法接收的参数是一个函数,所以会被解释成then(null) Promise.resolve(1).then(2).then(Promise.resolve(3)).then(console.log...; } 第一次看没啥思路,看到秒脑子里反射出定时器,然后应该是递归的因为它没说什么时候停,那第一步实现一个函数传入两个参数一个时间,一个函数,然后多少秒执行这个函数;第二步把具体的秒数对于具体的函数。.../zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Promise/all JavaScript Promises: 9 Questions:https...://danlevy.net/javascript-promises-quiz/ 阮一峰-Promise对象:http://es6.ruanyifeng.com/#docs/promise 选自《Javascript...筑基》系列文章 原文地址:https://github.com/ataola/JavaScript-Tsukuki/blob/master/note/promise-01.md
Promise 类有 .then() .catch() 和 .finally() 三个方法,这三个方法的参数都是一个函数,.then() 可以将参数中的函数添加到当前 Promise 的正常执行序列,.....then() 传入的函数会按顺序依次执行,有任何异常都会直接跳到 catch 序列: 实例 new Promise(function (resolve, reject) { console.log...Promise 函数 上述的 "计时器" 程序看上去比函数瀑布还要长,所以我们可以将它的核心部分写成一个 Promise 函数: 实例 function print(delay, message) {...对象的函数称作 Promise 函数,它常常用于开发基于异步操作的库。...Q: 什么时候适合用 Promise 而不是传统回调函数?
promise介绍 使用: function getMessageData() { var queryUrl = "http://1.1.1.1:1"; var param = {}; return...new Promise((resolve, reject)=>{ request.post(queryUrl, JSON.stringify(param), function(result){...function getMessageData() { var queryUrl = "http://1.1.1.1:1"; var param = {}; return new Promise...console.log(error) reject(error) }) }).then(data => { var param = data; return new Promise
永远都不应该依赖于不同 Promise 间回调的顺序和调度。 # 回调未调用 没有任何东西(甚至 JavaScript 错误)能阻止 Promise 通知它的决议(如果它决议了的话)。...如果在 Promise 的创建过程中或在查看其决议结果过程中的任何时间点上出现了一个 JavaScript 异常错 误,比如一个 TypeError 或 ReferenceError ,那这个异常就会被捕捉...Promise 甚至把 JavaScript 异常也变成了异步行为,进而极大降低了竞态条件出现的可能。 # 是可信任的 Promise 吗 Promise 并没有完全摆脱回调。...这个函数接受两个函数回调,用以支持 promise 的决议。...可以利用一些工具把需要回调的函数封装为支持 Promise 的函数,这个动作有时被称为“提升”或“Promise 工厂化”。
目录 函数的嵌套定义(掌握) 函数的嵌套调用(掌握) 函数的嵌套定义(掌握) 函数内部定义的函数,无法在函数外部使用内部定义的函数。...is not defined def f1(): def f2(): print('from f2') f2() f1() from f2 现在有一个需求,通过给一个函数传参即可求得某个圆的面积或者圆的周长...action='perimeter')}") circle(10): 314.1592653589793 circle(10,action='perimeter'): 62.83185307179586 函数的嵌套调用
在JavaScript中,一些操作是异步的。这意味着当这些操作完成时,它们产出的结果或者值并不会立即生效。 Promise是一个特殊的JavaScript对象,它代表了异步操作的最终结果。...回调函数 在拥有JavaScript Promise之前,处理异步操作最优雅的方式是使用回调。当异步操作的结果就绪时,回调就是一个运行的函数。...使用嵌套回调来完成这样的任务是非常痛苦的。幸运的是,Promise为我们提供了一种更简洁的语法,使我们能够将异步命令串联起来,让它们一个接一个地运行。...该构造函数用于封装尚未支持Promise的函数或API,例如上面的XMLHttpRequest对象。传递给Promise构造函数的回调包含用于从远程服务获取数据的异步代码。...请注意,如果你想了解更多有关使用JavaScript实现一个sleep函数,你可能对这篇文章[2]感兴趣。
async函数async函数是一个特殊的函数,它内部包含异步操作,并且返回一个Promise对象。...在async函数中,我们可以使用await关键字来等待一个Promise对象的解析,并在解析完成后继续执行下一行代码。...关键字在async函数内部,可以使用await关键字来等待一个Promise对象的解析。...await会暂停async函数的执行,直到Promise对象的状态变为已解析(resolved)并返回结果,然后将结果赋值给变量。...在等待期间,async函数会暂停执行,直到promise对象的状态变为已解析。
Promise 构造函数执行时会立即调用 executor 函数, resolve 和 reject 两个函数作为参数传递给 executor(executor 函数在 Promise 构造函数返回新建对象前被调用...如果在 executor 函数中抛出一个错误,那么该 promise 状态为 rejected。executor函数的返回值被忽略。...这时,前一个回调函数,有可能返回的还是一个 Promise 对象(即有异步操作),这时后一个回调函数,就会等待该 Promise 对象的状态发生变化,才会被调用。...request.open(method, url); request.send(data); }); } 总结 优点: 可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数...参考资料 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Promise http://
我们说处理javascript异步最常用的方式就是通过回调函数,对于回调函数我们昨天对此做了介绍 简单快速, 我们一般使用嵌套回调或者链式回调,会产生以下问题 当采用嵌套回调时,会导致层级太多,不利于维护...所以我们又采用了链式回调,对嵌套回调进行拆分,拆分后的函数间耦合度很高, 如果需要传递参数,函数之间的关联性会更高,而且要对参数进行校验以提高代码的健壮性 如果将我们自己的回调函数传递给第三方插件或者库...,就要考虑一些不可控因素 调用回调过早 调用回调过晚(或不被调用) 调用回调次数过多或者过少 promise的存在就是为了解决以上问题 虽然我们日常写回调函数不会有这么严格的要求,但是如果不这样去写回调函数...) 回调函数调用过早 调用过早就是将异步函数作为同步处理了, 我们之前说过,javascript以单线程同步的方式执行主线程,遇到异步会将异步函数放入到任务队列中, 当主线程执行完毕,会循环执行任务队列中的函数...回调函数调用过晚 回调函数调用过晚的处理原理和调用过早很类似, 在promise的then()中存放着异步函数,所有的异步都存在于js的任务队列中,当js的主线程执行完毕后,会依次执行任务队列中的内容