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

多层嵌套 promise then 执行顺序

在看 js 事件循环的时候,看到一个有趣的 promise then 执行顺序的题,想了好久,终于想明白了,这里记录一下。 大家先想下这里的执行顺序是什么。...,会先放入微任务队列,继续向下寻找同步任务,同步任务执行完之后,开始执行微任务。...执行到 22 行逻辑: 这里当执行到 22 行时, then的参数整体作为一个函数放入微任务队列中,因为这里还没执行,所以 555 的 then 就暂时不执行,继续下一个 333 的 then 放入微任务队列...,接下来没有同步任务了,开始执行微任务队列,当执行到 23 行的时候,这个微任务先执行 promise 同步函数,将then 444 又放入了 微任务队列,接下来没有课执行的同步任务了,则开始执行微任务队列...22-34 行执行结束: 进入下一个宏任务,执行第 3 行,同步任务,打印 666,执行 4-5 行,同步任务,进入 then,执行 7 行,微任务。

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

    js --- 执行机制

    JS为什么是单线程的?  JS最初被设计用在浏览器中,那么想象一下,如果浏览器中的JS是多线程的。...process1 删除了该dom,而process2 编辑了该dom,同时下达2个矛盾的命令,浏览器究竟该如何执行呢? 2 JS为什么需要异步?...如果JS中不存在异步,只能自上而下执行,如果上一行解析时间很长,那么下面的代码就会被阻塞。 对于用户而言,阻塞就意味着"卡死",这样就导致了很差的用户体验 3 JS单线程又是如何实现异步的呢?   ...是通过的事件循环(event loop),理解了event loop机制,就理解了JS执行机制。...,而是延迟了一段时间,满足一定条件后才去执行的,这类代码,我们叫异步代码。

    6.3K20

    JS执行机制

    JS执行机制 以下代码执行的结果是什么?...console.log(1); setTimeout(function () { console.log(3); }, 0); console.log(2); 1.1 JS 是单线程...单线程就意味着,所有任务需要排队,前一个任务结束,才会执行后一个任务。这样所导致的问题是: 如果 JS 执行的时间过长,这样就会造成页面的渲染不连贯,导致页面渲染加载阻塞的感觉。...于是,JS 中出现了同步任务和异步任务。 同步 ​   前一个任务结束后再执行后一个任务,程序的执行顺序与任务的排列顺序是一致的、同步的。...他们的本质区别: 这条流水线上各个流程的执行顺序不同。 1.3 JS执行机制(事件循环) 1. 先执行执行栈中的同步任务。 2. 异步任务(回调函数)放入任务队列中。 3.

    7.4K20

    JS执行顺序

    javascript给人的直观感受是,从上往下执行,但实际上却不是这样的,先看个例子 1. console.log(test); 2. var test = "你好"; 3. console.log(...因为javascript执行时,在同一个作用域内是先编译再执行 编译的时候会编译 function 和 var 这两个关键词定义的变量,编译完成后从上往下执行并向变量赋值 所以执行第1行时, var test...已经执行过了,所以test不会报错,而test2就会报错 需要注意的是,对 var test 执行编译时,只是先定义了 test 这个变量,并不会把 "你好" 这个值赋给test,而是到第2行时才给test...赋值的,这就是为什么第1行的执行结果是 undefined 对于上面的例子,可以这样理解 //先编译 var 定义的变量 1. var test; //编译完成后,从上到下执行代码 2. console.log...//执行结果是"你好" function test() { console.log("你好"); } 模拟编译执行过程 //找到 function 定义的部分进行编译 //以函数名作为变量名,同时用函数赋值

    9.2K60

    keras多层感知器识别手写数字执行预测代码_感知机模型多层神经网络

    2.Keras建立多层感知器模型(接上一篇) 2.1简单介绍多层感知器模型 注:以下模型及其说明来自于《TensorFlow+Keras深度学习人工智能实践应用》林大贵 著 以矩阵方式仿真多层感知器模型的工作方式...2.2建立多层感知器模型的步骤 建立多层感知器模型识别MNIST数据集中的手写数字步骤如下图所示 2.3对数据进行预处理 输入上一篇文章讲到的关键代码 import numpy as np...表示要训练10个周期 batch_size=200 表示每个周期中的每一批次的数据量大小是200 verbose=2 显示训练过程 train_history 训练结果会保存在train_history中 执行代码...validation'],loc='upper left') plt.show() 画出准确率曲线 show_train_history(train_history,'acc','val_acc') 执行结果...pd pd.crosstab(y_test_label,prediction,rownames=['lable'],colnames=['prediction']) 运行结果 根据经验,可以看出多层感知器模型识别的准确率不是很高

    45510

    JS判断滚动条是否停止滚动

    想到的解决方案是,当滚动条停止时,再去发请求计算数据。那么问题来了,如何判断滚动条是否停止了呢?        解决:搜索了一下,js本身是无法判断滚动条是在滚动状态还是停止状态,只有通过其它方式了。...后来想到的思路是当滚动条滚动的时候,发起一个定期执行的方法,并记录一次当前滚动条到顶部的距离,这个方法中判断此时滚动条到顶部的距离是否和上次记录的相等,如果相等,那么说明停止滚动了,不相等,还在滚动。...上次滚动条到顶部的距离 interval = null;// 定时器 document.onscroll = function() { if(interval == null)// 未发起时,启动定时器,1秒1执行...interval); interval = null; } } //-->        可以设置定时执行的时间

    17.4K00

    mongodb执行js脚本(一)---shell执行

    mongodb执行js脚本(一)---shell执行 2015年06月09日 10:58:36 张小凡vip 阅读数 21310更多 所属专栏: mongodb基础与运用 版权声明:本文为博主原创文章...js脚本进行复杂的管理 mongodb 的shell是javascript实现的,如果直接使用js实现相应的功能则显得很直观和简便。...比如我们对一些数据进行 统计计算,除了使用mapreduce之外,直接使用js也是很好的选择。...还有一些批处理,数据同步都可以使用js 使用js脚本进行交互的优点与缺点 (1)无需任何驱动或语言支持; (2)方便cron或管理员定时任务; (3)注意点:任然是数据格式的问题;...js脚本一般会用来执行以下任务 (1)备份; (2)调度map-reduce命令; (3)离线报告,离线任务; (4)管理员定时任务; 如何运行一个js脚本 .

    9.4K30

    xxljo点击停止任务,任务还在执行,这种咋解决

    目录 1 问题 2 实现 1 问题 在使用xxljob 的时候,我自己写了一个方法 @xxljob(“www”) ,里面的逻辑要执行10分钟,就是循环下载大文件,所以执行的时间长,但是在点击执行一次之后...,我到日志里面,点击停止任务,日志里面写的停止了,但是我看见我项目里面,后台还在下载文件,根本没有停止,这种情况咋解决,也就是任务逻辑执行时间长,点击停止,任务其实没有停止,还在执行; 有知道咋解决嘛,...我就想即使我任务逻辑执行10分钟时间,我点击停止之后,你任务就立马停止,不应该背后偷偷下载 2 实现 问题可能是因为你的任务逻辑并没有实现可中断的机制, 导致在点击停止之后,任务并没有立即停止。...除此之外,你还可以通过增加任务的超时时间来防止任务执行时间过长, 超过一定时间后自动停止任务。可以在xxl-job-admin中修改超时时间, 使任务在规定的时间内完成执行,超时后就会被停止。...最后,建议你在任务逻辑执行较长时间时, 仔细评估任务的执行时间和资源消耗, 以避免任务过度耗费资源,影响其他任务和系统的正常运行。

    2.7K10

    js 立即执行函数

    立即执行函数 目录 立即执行函数 作用 参数 返回值 立即执行函数 立即执行函数模式是一种语法,可以让你的函数在定义后立即被执行。...立即执行函数的组成 定义一个函数 将整个函数包裹在一对括号中 将函数声明转换为表达式 在结尾加上一对括号 让函数立即被执行 代码实例 (function () { console.log("...app") })() 作用 页面加载完成后只执行一次的设置函数。...注意 通常你不应该给立即执行函数传递太多的参数,因为它很快会成为一个负担——为了理解代码是如何工作的,你不得不经常上下滚动源代码。...返回值 就像其它任何函数一样,一个立即执行函数也能返回值并且可以赋值给其它变量。 var num = (function () { return 4 })() console.log(num)

    6.2K20
    领券