首页
学习
活动
专区
工具
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执行顺序

背景 众所周知,JS是单线程语言,但它支持异步操作,其核心机制就是JS引擎的事件循环。...原理 总的来说,流程图如下: Promise的代码块是立即执行的。...console.log(3) }) console.log(4) // 4 2 3 1 我们把setTimeout放在最开始,而且不管设置了几次nextTick,setTimeout里的函数体总是最后执行的...,所以它们按顺序排列; 2是宏任务,会放到下一次事件循环时执行; 4是微任务,在首次运行时就把它添加到了微任务队列,所以在下一次事件循环之前就会被执行。...通过这样的事件循环,使得单线程的JS也可以拥有异步的能力,使得如AJAX请求这样费时间的操作可以被安排到后面来执行,不影响页面的加载和渲染。

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

JS的asyncawait的执行顺序详解

http://es6.ruanyifeng.com/#docs/async)后拓展了一下,我理了一下await之后js执行顺序,希望可以给别人解疑答惑,先简单介绍一下async/await。...await后面的函数会先执行一遍,然后就会跳出整个async函数执行后面js栈(后面会详述)的代码。...,等本轮事件循环执行结束后,又会跳回到async函数(test函数),等待之前await 后面表达式的返回值,因为testSometing 不是async函数,所以返回的是一个字符串“testSometing...这个就是在async/await 函数之后js执行顺序,我们再看一个列子把testSometing函数前面加上async async function testSometing() { console.log...async/await进行异步操作时js执行顺序

8.8K40

JavaScript Alert 函数执行顺序问题

于是便有了事件循环(event loop)的产生,JavaScript 将一些异步操作或 有I/O 阻塞的操作全都放到一个事件队列,先顺序执行同步 CPU代码,等到 JavaScript 引擎没有同步代码...由上述原因,导致了诡异的 “Alert执行顺序问题”。 我们无法将页面渲染变成同步操作,那么只好把 alert() 变为异步代码,从而才能在页面渲染之后执行。...其实大多数情况下我们替换掉 alert 并不是它不符合我们期待的执行顺序,而是因为它实在是太丑了,而且也不支持各种美化,可以想像在一个某一特定主题的网站上忽然弹出来一个灰色单调的对话框是多么不和谐。...前端的同学应该对 setTimeout() 这个函数不陌生,使用它,可以延迟执行某些代码。...小结 ---- 在上面的两个解决方案,都利用了 JavaScript 的回调函数,前者将函数所为 alert 的参数并绑定到 DOM 的 onclick 事件,后者使用 setTimeout 将函数转为异步执行

3K40

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匿名函数和立即执行函数

js匿名函数和立即执行函数 1. 匿名函数 a)写法 b) 特点 2. 立即执行函数 a) 写法 b) 特点 c) 示例 1. 匿名函数 匿名函数又叫拉姆达函数, 使用前需要先赋值。...var hello=function(){ console.log("hello"); }; hello();//hello b) 特点 匿名函数可以直接访问到外层署名函数(Foo)的变量...(使用关键字var定义的),但不能访问外层署名函数的属性(使用关键字this定义的) 匿名函数既可以直接访问外层匿名函数的变量,也可以直接访问外层匿名函数的属性 外层函数类型: 署名函数 匿名函数...立即执行函数 该类函数没有声明,直接执行执行完立即释放。一般做初始化比较合适。...,如function (){}(),这样不行,因为function (){}是声明不是表达式,如果是var fn=function (){}();就可以 但执行后,函数名或者变量就不代表函数了,被执行符号执行的表达式其函数名字将被忽略

2.5K20

Java静态代码块、代码块以及构造函数执行顺序详解

静态代码块,代码块,构造方法执行顺序 前段时间面试,做到一个笔试题主要考察的是静态代码块,代码块,构造方法的执行顺序,由于自己没复习所以这个题肯定没做出来,回家后在Idea中进行代码测试运行。...可以看出到实际上执行顺序应该是父类静态代码块——>子类静态代码块——>父类代码块——>父类构造方法——>子类代码块——>子类构造方法。 为什么先执行父类的静态代码块呢? 但是为什么会这样呢?...为什么第二个执行代码块? 讲完了静态代码块是最优先执行的,但是为什么代码块的执行顺序会比构造方法先呢?我们通过反编译工具来看一下 ?...通过反编译工具发现,代码块实际上是被放到了构造方法,且是放在了构造方法的第一行,那么就不难解释为什么代码块会比构造方法执行顺序靠前。...,所以此时就会执行父类的代码块以及构造方法,当super执行完毕回到子类时,由于子类的代码块也被放到了构造方法,且在super之后所以执行子类代码块再执行子类构造方法。

1.3K30

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

浏览器是多线程的,JS是单线程的(浏览器只分配一个线程来执行JS)   进程大线程小:一个进程包含多个线程,例如在浏览器打开一个HTML页面就占用了一个进程,加载页面的时候,浏览器分配一个线程去计算...[宏任务:macro task] - 定时器 - 事件绑定 - ajax - 回调函数 - Nodefs可以进行异步的I...执行顺序优先级:SYNC => MICRO => MACRO 所有JS的异步编程仅仅是根据某些机制来管控任务的执行顺序,不存在同时执行两个任务这一说法 先来看一个例子: setTimeout(()...我们用ajax来看看js的同步与异步的执行顺序和机制,AJAX任务开始:SEND,AJAX任务结束:状态为4 let xhr = new XMLHttpRequest(); xhr.open('GET'...// 状态为3 把函数执行 // 状态为4 把函数执行

2K10

Java 静态块、构造块、构造函数执行顺序

Java代码行执行顺序: 1.静态块:用static声明,JVM加载类时执行,仅执行一次 2.构造块:类中直接用{}定义,每次创建对象时执行 3.执行顺序优先级:静态块>main()>构造块>构造方法...出现继承时: 1.初始化父类的静态变量、静态代码块,初始化的顺序按照出现的顺序。 2.初始化子类的静态变量,静态代码块。 3.初始化父类的成员变量。 4.执行父类的构造函数。...6.构造代码块创建对象时执行 7.执行子类的构造函数。...$; n=100 m=210** 结果(三):【将Father类的两个引用p、p1注释掉的运行结果,结果二的new Son();也注释掉】 父类%%静态块%%调用; m=10 父类**构造块...**调用;n=10 m=20 父类$$构造函数$$; n=100 m=30 结果(四):【将Father类的两个引用p、p1注释掉的运行结果,结果二的new Son();不注释掉】 父类

1.6K30

一文读懂 Golang init 函数执行顺序

2.执行顺序 既然一个程序可以有多个 init 函数,那么对于位于不同包、不同源文件的多个 init 函数,其执行顺序是怎样的呢? 下面从多个方面去考察。.../main init a init b init c init main main 结论: 同一个包不同源文件 init 函数执行顺序,是根据文件名的字典序来确定。...2.4 包级变量初始化与 init 函数执行顺序 如果包存在包级变量,那么其初始化与 init 函数执行先后顺序如何呢?...程序如果在不同包的不同源文件有多个 init 函数时,其执行顺序可概述为: 同一个源文件的 init 函数执行顺序与其定义顺序一致,从上到下; 同一个包不同文件的 init 函数执行顺序按照文件名的字典序...; 对于不同的包,如果不相互依赖的话,按照 main 包 import 的顺序调用其包的 init 函数; 如果包存在依赖,不同包的 init 函数按照包导入的依赖关系决定执行顺序

4.7K43
领券