首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JavaScript执行——Promise

值得注意的是,Promise新建后就会立即执行。...执行顺序   接下来我们探究一下它的执行顺序,看以下代码: let promise = new Promise(function(resolve, reject){ console.log(...表明,在Promise新建后会立即执行,所以 首先输出AAA。然后,then方法指定的回调函数将在当前脚本所有同步任务执行完后才会执行,所以 BBB最后输出。...特点体现在以下四点: 内置执行器 更好的语义 更广的适用性 返回值是 Promise await   顾名思义,等待。正常情况下,await命令后面是一个 Promise 对象,返回该对象的结果。...在该函数中,利用await来等待一个Promise。 Promise优缺点 优点 缺点 解决回调 无法监测进行状态 链式调用 新建立即执行且无法取消 减少嵌套 内部错误无法抛出

66120
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    打开Promise的正确姿势

    让作者为你带来打开Promise的正确姿势,让你使用Promise的时候用的更爽,后人接手你的代码看的更爽,也避免出现莫名其妙的问题而无法对问题进行定位的情况。...如果我们像使用回调一样使用Promise,虽然结果是正确的,但是这完全没有利用到Promise的优势。...Promise与循环 上面讲到了异步操作的顺序执行,那如果我们需要同时执行一组异步操作呢? 举个例子,我们需要删除指定项目ID下的所有子模块。...Promise实例中多次调用.then绑定回调方法,当该Promise实例状态变化时,将按调用.then的顺序执行回调方法。...1004 是的,正如我们所想,promise2的onRjected回调方法正确的处理了来自promise的rejected状态。

    79510

    Promise、setTimeout的执行顺序

    同步和异步任务 ​ 要了解异步线程我们首先应该明白它的用处,因为js的单线程特性,任务的执行顺序都是依次执行,而当我们在工作中遇到网络请求,前后端交互的时候,你的数据不会马上拿到,这需要时间,如果等拿到数据再执行下面的代码...,然后继续执行后面的任务,当完成了执行栈里的同步任务之后,再检测是否有异步任务需要执行,最后执行异步任务。...1.3.4.2 ,我们首先找到同步任务,1 3 是同步任务,然后执行异步任务,异步任务如果按顺序执行则是24 但是答案是4.2那么我们可以知道 promise的执行顺序优先于setTimeout所以由此可知...= new Promise((resolve, reject) => { console.log(1); console.log(2); }); promise.then(()...微任务, 直接执行 new Promise 输出 5, 并将 then 函数的回调函数推入 micro Task 的 event queue 中, micro Task 的 event queue 中记

    67720

    多层嵌套 promise then 执行顺序

    在看 js 事件循环的时候,看到一个有趣的 promise then 执行顺序的题,想了好久,终于想明白了,这里记录一下。 大家先想下这里的执行顺序是什么。...,这里首先要明确一点  promise then函数回调执行完毕后才会开始下一个 then 函数,当多个 then 链式调用的时候,如果一个 then 函数放入微任务队列,没有执行完,则之后的 then...首先,大家都知道 setTimeout 是宏任务,则一定在下一轮事件循环的时候才执行,则他的执行优先级最低,promise是同步任务,会先执行,promise.then() 是微任务,当遇到微任务的时候...,接下来没有同步任务了,开始执行微任务队列,当执行到 23 行的时候,这个微任务先执行 promise 同步函数,将then 444 又放入了 微任务队列,接下来没有课执行的同步任务了,则开始执行微任务队列...22-34 行执行结束: 进入下一个宏任务,执行第 3 行,同步任务,打印 666,执行 4-5 行,同步任务,进入 then,执行 7 行,微任务。

    1.7K40

    JS异步执行,Promise用法

    值得注意的是,Promise新建后就会立即执行。...执行顺序   接下来我们探究一下它的执行顺序,看以下代码: let promise = new Promise(function(resolve, reject){ console.log("AAA...表明,在Promise新建后会立即执行,所以首先输出 AAA。然后,then方法指定的回调函数将在当前脚本所有同步任务执行完后才会执行,所以BBB 最后输出。...特点体现在以下四点: 内置执行器 更好的语义 更广的适用性 返回值是 Promise await   顾名思义,等待。正常情况下,await命令后面是一个 Promise 对象,返回该对象的结果。...在该函数中,利用await来等待一个Promise。 Promise优缺点 优点 缺点 解决回调 无法监测进行状态 链式调用 新建立即执行且无法取消 减少嵌套 内部错误无法抛出

    5.4K30

    Docker API未授权命令执行

    当Docker节点的2375端口直接暴露并未做权限检查时,存在未授权访问漏洞,攻击者可以利用Docker API执行任何操作,包括执行Docker命令,创建、删除Docker以及获得宿主机权限等。...漏洞复现 访问目标的2375端口如下接口,若有信息,则存在Docker API未授权访问 http://x.x.x.x:2375/version http://x.x.x.x:2375/images http...我们可以执行如下命令启动一个未开启的容器,然后将宿主机的磁盘挂载到容器中。...chroot /opt bash#然后就可以执行如下一些命令,但是查看的ip和反弹shell等一些命令,还是容器内的historycat /etc/passwd 写入SSH公钥 执行如下命令将本地的authorized_keys...执行如下命令,将反弹shell的命令写入/var/spool/cron/root文件中。

    1.3K20

    springboot mybatis缓存_secure boot未正确配置

    在同一个SqlSession中,执行相同的查询sql,第一次会先去查询数据库,并写入缓存。第二次再执行时,则直接从缓存中取数据。...如果两次执行查询sql的中间执行了增删改操作,则会清空该SqlSession的缓存。 二级缓存是mapper级别的缓存。作用域是是mapper的同一个namespace下的sql语句。...第一次执行查询SQL时,会将查询结果存到二级缓存区域内。第二次执行相同的查询SQL,则直接从缓存中取出数据。如果两次执行查询sql的中间执行了增删改操作,则会清空该namespace下的二级缓存。...: 插入用户并执行查询: 从上图的执行结果可以看到,先进行查询操作,查询结果更新到缓存,后面的几次查询都是直接从缓存取值。...之后执行一个插入用户的操作,再多次执行查询操作的时候,会先调用一次查询语句将查询结果写入缓存,后面的几次操作就会直接从缓存取值。

    1K50

    settimeout(fn 0)与Promise的执行顺序

    这里涉及到三个“何时”: setTimeout(fn, 0)何时执行 promise函数何时执行 then何时执行 下面我们来一一分析。 1. setTimeout(fn, 0)何时执行?...而settimeout(fn, 0)表示立即执行,也就是用来改变任务的执行顺序,要求浏览器”尽可能快“的进行回调。 2. promise何时执行?...新建后立即执行,也就是说,Promise构造函数里的代码是同步执行的。...接着, 会先执行 macrotask 中的第一个任务(整个 script中的同步代码 ),再加上promise 构造函数也是同步的(promise.then 回调被推进到 microtask 队列中),...所以会先打印出2 10 3,然后继续执行末尾的,打印出5 此时,已经执行完了第一个 macrotask , 所以接下来会顺序执行所有的 microtask, 也就是 promise.then 的回调函数

    1.4K30

    Joomla未授权访问漏洞到代码执行

    CMS中的一个未授权访问漏洞(CVE-2023-23752),目前该漏洞的细节及PoC/EXP已公开。 漏洞介绍 在 Joomla!...CMS 版本4.0.0-4.2.7中 由于对web 服务端点访问限制不当,可能导致未授权访问Rest API,造成敏感信息泄露(如数据库账号密码等)。...未授权路径在: /api/index.php/v1/config/application?public=true 我们可以直接看到数据库的配置信息。...text.txt即可,自用写死了 结果会生成result.txt在目录下: 结果是写入的漏洞地址: 但这里推荐一款使用python编写的验证工具,也可以批量验证该漏洞 工具下载地址,见文章底部 代码执行思路...使用未_绑定_到127.0.0.1. Censys 显示了数千个 Joomla! 服务器与暴露的 MySQL 服务器位于同一位置。

    57010

    JavaScript执行(一):Promise里的代码为什么比setTimeout先执行?

    Promise 的 then 回调是一个异步的执行过程,下面我们就来研究一下 Promise 函数中的执行顺序,我们来看一段代码示例: var r = new Promise(function(resolve...在这段代码中,我设置了两段互不相干的异步操作:通过 setTimeout 执行 console.log(“d”),通过 Promise 执行 console.log(“c”)。...为了理解微任务始终先于宏任务,我们设计一个实验:执行一个耗时 1 秒的 Promise。...我们可以看到,即使耗时一秒的 c1 执行完毕,再 enque 的 c2,仍然先于 d 执行了,这很好地解释了微任务优先的原理。 通过一系列的实验,我们可以总结一下如何分析异步执行的顺序: 1. ...根据调用次序,确定宏任务中的微任务执行次序; 4. 根据宏任务的触发规则和调用次序,确定宏任务的执行次序; 5.

    59710
    领券