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

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
您找到你想要的搜索结果了吗?
是的
没有找到

JS如何控制任务的执行顺序

Eat supper~ 从这里不难看出,这里主要的点是链式调用和流程控制 链式调用很简单,核心的点就是函数执行完后 返回 this,栗子: class EatMan { eat(food) {...${food} ~`); return this; } } new EatMan().eat('apple').eat('pear') 这样就实现链式调用了,下面上主菜 - 控制任务的执行顺序...这里参考某些中间件的实现思路,首先创建一个任务队列,把每个函数放进去,按顺序执行,每个函数执行完成后调用一个 next 函数,执行下一个函数 class EatMan { constructor(...{ this.name = name; this.tasks = []; this.init(); // 利用 setTimeout 的机制 在下一个事件循环才开始执行...Eat dinner~ Eat supper~ 首发自:JS如何控制任务的执行顺序 - 小鑫の随笔

3.5K30

ajax 和 js 事件的执行顺序

有一个需求,滚轮滚动到相应位置的时候执行当前的动画,这个动画在footer里面,而网页的主体通过ajax进行渲染,我在js里面调用ajax渲染数据,然后再获取主体的高度,滚动到该高度的时候执行动画。...我大致想了两种解决办法,均以失败告终,本地是ajax先执行,服务器是js执行。...ajax的success回调里面,结果是只有打开网页第一次能够成功,然后不管刷新多少次均无效,事件被屏蔽,所以方法二也被废除; 最后我想到了,ajax不就是一种异步方法,我将其改为同步不就行,先让ajax执行完在执行...js事件。...当然这样做有弊端的,如果接口出问题,ajax渲染失败,那么整个网页的js都将执行不了。不过我想真到了数据都渲染不出的地方,访问网页就没有意义了,所以最后我采用了这种方法。

2.9K30

Js篇-面试题2-Promise 执行顺序问题

Promise 执行问题 写出下面一段程序的输出的结果 new Promise(resolve => { console.log(1); setTimeout(() => console.log...console.log(3)) resolve(); }).then(() => console.log(4)) console.log(5) 答案: 1 5 3 4 2 解析:事件循环,任务队列的执行顺序...,new Promise是会立即调用,接收了一个resolve参数,执行调用输出console.log(1)语句,遇到setTimeout,它是一个异步宏任务,会推送到任务队列中,进入挂起状态 而promise.resove...也是一个异步微任务,仍然会推送到任务队列中,进入挂起状态,当主线程console.log(5)执行完后,在从异步任务队列中进行执行,在同一栈中,微任务要优先于宏任务的执行,所以先执行 3,然后 4,最后是...2 最终执行顺序结果是:1,5,3,4,2

1.3K10

面试:Vue.js嵌套组件生命周期执行顺序是什么?

组件B,组件C,组件C是组件B的子组件,组件B又是组件A的子组件,那么直观的层级结构如下: ComponentA --ComponentB ----ComponentC 问:他们之间生命周期函数的调用顺序是什么...beforeCreate、created 和 beforeMount,然后再去执行子组件的beforeCreate、created 和 beforeMount,如果子组件下面没有子组件了,就执行 mounted...,然后再返回父级执行 mounted。...Vue嵌套组件生命周期执行顺序 完! ---- 本文代表个人观点,内容仅供参考。若有不恰当之处,望不吝赐教! 如果对你有一点点帮助,可以点个关注。...本文链接:https://zhangbing.site/2018/12/05/Vue-js嵌套组件生命周期执行顺序/。

1.9K20

JS中的同步异步编程,宏任务与微任务的执行顺序

浏览器是多线程的,JS是单线程的(浏览器只分配一个线程来执行JS)   进程大线程小:一个进程中包含多个线程,例如在浏览器中打开一个HTML页面就占用了一个进程,加载页面的时候,浏览器分配一个线程去计算...DOM树,分配其它的线程去加载对应的资源文件...再分配一个线程去自上而下执行JS   同步:在一个线程上(主栈/主任务队列)同一个时间只能做一件事情,当前事情完成才能进行下一个事情(先把一个任务进栈执行...执行顺序优先级:SYNC => MICRO => MACRO 所有JS中的异步编程仅仅是根据某些机制来管控任务的执行顺序,不存在同时执行两个任务这一说法 先来看一个例子: setTimeout(()...我们用ajax来看看js的同步与异步的执行顺序和机制,AJAX任务开始:SEND,AJAX任务结束:状态为4 let xhr = new XMLHttpRequest(); xhr.open('GET'...// 状态为3 把函数执行 // 状态为4 把函数执行

2K10

面试官:说说Event Loop事件循环、微任务、宏任务

为了解决这个问题,JS中出现了同步和异步。他们的本质区别是:一条流水线上各个流程的执行顺序不同。在讲JS任务执行机制前,先要了解一下什么是同步任务与异步任务。...同步任务:即主线程上的任务,按照顺序由上⾄下依次⾏,当前⼀个任务⾏完毕后,才能⾏下⼀个任务。异步任务:不进⼊主线程,⽽是进⼊任务队列的任务,执行完毕之后会产生一个回调函数,并且通知主线程。...其实是声明了⼀个promise,promise是同步代码,会顺序⾏打印async2函数里的4 ,只有.then⾥⾯的代码会加⼊微任务队列⾥,这⾥相当于⾏了async2()之后,再将后面的代码加⼊⼀个微任务队列中...为了解决这个问题,JS中出现了同步和异步。他们的本质区别是:一条流水线上各个流程的执行顺序不同。在讲JS任务执行机制前,先要了解一下什么是同步任务与异步任务。...同步任务:即主线程上的任务,按照顺序由上⾄下依次⾏,当前⼀个任务⾏完毕后,才能⾏下⼀个任务。异步任务:不进⼊主线程,⽽是进⼊任务队列的任务,执行完毕之后会产生一个回调函数,并且通知主线程。

74340

面试官:说说Event Loop事件循环、微任务、宏任务5

前言JS是一门单线程语言,单线程就意味着,所有的任务需要排队,前一个任务结束,才会执行下一个任务。这样所导致的问题是:如果JS执行的时间过长,这样就会造成页面的渲染不连贯,导致页面渲染加载阻塞的觉。...为了解决这个问题,JS中出现了同步和异步。他们的本质区别是:一条流水线上各个流程的执行顺序不同。在讲JS任务执行机制前,先要了解一下什么是同步任务与异步任务。...同步任务:即主线程上的任务,按照顺序由上⾄下依次⾏,当前⼀个任务⾏完毕后,才能⾏下⼀个任务。异步任务:不进⼊主线程,⽽是进⼊任务队列的任务,执行完毕之后会产生一个回调函数,并且通知主线程。...,进⼊async1内部,async1其实是声明了⼀个promise,promise是同步代码,会顺序⾏打印async2函数里的4 ,只有.then⾥⾯的代码会加⼊微任务队列⾥,这⾥相当于⾏了async2...再依次执行第6行和第17行的两个微任务,打印3和97.微任务⾏结束,开始⾏宏任务setTimeout,打印11⾏的6.总结所有同步任务都在主线程上执行,形成一个执行栈(call stack)。

73020

面试官:说说Event Loop事件循环、微任务、宏任务

前言JS是一门单线程语言,单线程就意味着,所有的任务需要排队,前一个任务结束,才会执行下一个任务。这样所导致的问题是:如果JS执行的时间过长,这样就会造成页面的渲染不连贯,导致页面渲染加载阻塞的觉。...为了解决这个问题,JS中出现了同步和异步。他们的本质区别是:一条流水线上各个流程的执行顺序不同。在讲JS任务执行机制前,先要了解一下什么是同步任务与异步任务。...同步任务:即主线程上的任务,按照顺序由上⾄下依次⾏,当前⼀个任务⾏完毕后,才能⾏下⼀个任务。异步任务:不进⼊主线程,⽽是进⼊任务队列的任务,执行完毕之后会产生一个回调函数,并且通知主线程。...其实是声明了⼀个promise,promise是同步代码,会顺序⾏打印async2函数里的4 ,只有.then⾥⾯的代码会加⼊微任务队列⾥,这⾥相当于⾏了async2()之后,再将后面的代码加⼊⼀个微任务队列中...再依次执行第6行和第17行的两个微任务,打印3和97.微任务⾏结束,开始⾏宏任务setTimeout,打印11⾏的6.总结所有同步任务都在主线程上执行,形成一个执行栈(call stack)。

1.8K31

面试官:说说Event Loop事件循环、微任务、宏任务_2023-02-28

前言JS是一门单线程语言,单线程就意味着,所有的任务需要排队,前一个任务结束,才会执行下一个任务。这样所导致的问题是:如果JS执行的时间过长,这样就会造成页面的渲染不连贯,导致页面渲染加载阻塞的觉。...为了解决这个问题,JS中出现了同步和异步。他们的本质区别是:一条流水线上各个流程的执行顺序不同。在讲JS任务执行机制前,先要了解一下什么是同步任务与异步任务。...同步任务:即主线程上的任务,按照顺序由上⾄下依次⾏,当前⼀个任务⾏完毕后,才能⾏下⼀个任务。异步任务:不进⼊主线程,⽽是进⼊任务队列的任务,执行完毕之后会产生一个回调函数,并且通知主线程。...,进⼊async1内部,async1其实是声明了⼀个promise,promise是同步代码,会顺序⾏打印async2函数里的4 ,只有.then⾥⾯的代码会加⼊微任务队列⾥,这⾥相当于⾏了async2...再依次执行第6行和第17行的两个微任务,打印3和97.微任务⾏结束,开始⾏宏任务setTimeout,打印11⾏的6.总结所有同步任务都在主线程上执行,形成一个执行栈(call stack)。

81610

说说Event Loop事件循环、微任务、宏任务

前言JS是一门单线程语言,单线程就意味着,所有的任务需要排队,前一个任务结束,才会执行下一个任务。这样所导致的问题是:如果JS执行的时间过长,这样就会造成页面的渲染不连贯,导致页面渲染加载阻塞的觉。...为了解决这个问题,JS中出现了同步和异步。他们的本质区别是:一条流水线上各个流程的执行顺序不同。在讲JS任务执行机制前,先要了解一下什么是同步任务与异步任务。...同步任务:即主线程上的任务,按照顺序由上⾄下依次⾏,当前⼀个任务⾏完毕后,才能⾏下⼀个任务。异步任务:不进⼊主线程,⽽是进⼊任务队列的任务,执行完毕之后会产生一个回调函数,并且通知主线程。...,进⼊async1内部,async1其实是声明了⼀个promise,promise是同步代码,会顺序⾏打印async2函数里的4 ,只有.then⾥⾯的代码会加⼊微任务队列⾥,这⾥相当于⾏了async2...再依次执行第6行和第17行的两个微任务,打印3和97.微任务⾏结束,开始⾏宏任务setTimeout,打印11⾏的6.总结所有同步任务都在主线程上执行,形成一个执行栈(call stack)。

68520

PlayWright(十四)- 前置和后置

# 注意: 函数级别顺序: # 先 setup() -> 用例1 -> teardown() ⽅, 再 setup() -> 用例2 -> teardown() ⽅ def setup...setup和teardown的时候是没有提示的,需要自己填写,第二点是执行顺序不是从上往下执行的,是按照setup() -> 用例1 -> teardown() ⽅, 再 setup() -> 用例2...# 注意: 类级别顺序: # 先 setup_class() -> 测试⽅1 -> 测试⽅2 ->teardown_class() ⽅ def setup_class(self...self): print('用例1') def test_02(self): print('用例2') 执行结果: 这里我们的执行顺序是setup_class..._02(self): # 6 print('用例2') 大家猜一下执行顺序是什么样的呢 执行结果: 1 -> 3 -> 5 -> 4 -> 3-> 6 -> 4 -> 2 前置和后置内容是不是也很简单

30320
领券