搜索
首页web前端js教程JavaScript调用堆栈及setTimeout使用方法深入剖析_javascript技巧

Javascript中会经常用到setTimeout来推迟一个函数的执行,如:

复制代码 代码如下:

setTimeout(function(){alert("Hello World");},1000);

会在执行到这句话后延迟1秒钟来弹出alert窗口。那么再看这一段:
复制代码 代码如下:

function a(){
setTimeout(function() {alert(1)}, 0);
alert(2);
}
a();

注意这段代码中的setTimeout延迟设为了0,就是延迟0毫秒,貌似是不做任何延迟立刻执行,即1,2。但实际的执行结果确是2,1。为什么?这得从Javascript调用堆栈(call stack)和setTimeout的功能说起。

首先,JavaScript是单线程的,即同一时间只执行一条代码,所以每一个JavaScript代码执行块会“阻塞”其它异步事件的执行。其次,和其他的编程语言一样,Javascript中的函数调用也是通过堆栈实现的。在执行函数a的时候,a先入栈,如果不给alert(1)加setTimeout,那么alert(1)第2个入栈,最后是alert(2)。但现在给alert(1)加上setTimeout后,alert(1)就被加入到了一个新的堆栈中等待,并“尽可能快”的执行。这个尽可能快就是指在a的堆栈完成后就立刻执行,因此实际的执行结果就是先alert(2),再alert(1)。在这里setTimeout实际上是让alert(1)脱离了当前函数调用堆栈。看下面一个例子:
复制代码 代码如下:



这样一段函数意图是每输入一个字符就把当前input里的所有字符都alert出来,但实际效果确是alert出按键之前的内容。这里,我们就可以利用setTimeout(0)来实现。
复制代码 代码如下:



这样当onkeydown事件触发的时候,alert就被放入了下一个调用堆栈,一旦onkeydown事件触发的堆栈关闭后就开始执行。当然浏览器还有个onkeyup事件也可以实现我们的需求。

这样的setTimeout用法在实际项目中还是会时常遇到。比如浏览器会聪明的等到一个函数堆栈结束后才改变DOM,如果再这个函数堆栈中把页面背景先从白色设为红色,再设回白色,那么浏览器会认为DOM没有发生任何改变而忽略这两句话,因此我们可以通过setTimeout把“设回白色”函数加入下一个堆栈,那么就可以确保背景颜色发生过改变了(虽然速度很快可能无法被察觉)。

总之,setTimeout增加了Javascript函数调用的灵活性,为函数执行顺序的调度提供极大便利。
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
iOS 17:如何在待机模式下自定义小部件iOS 17:如何在待机模式下自定义小部件Sep 17, 2023 pm 01:57 PM

待机是iOS17中一种新的可自定义锁屏模式,可在iPhone充电并侧卧时激活。可以将其视为iPhone的一种智能显示屏,例如,当您的设备在厨房,书桌或床头柜上充电时,可以快速访问可以远处查看的不同可浏览信息屏幕。自定义备用构件待机由三个屏幕组成,可以通过在iPhone显示屏上水平滑动来访问。第一个屏幕是交互式小部件所在的位置,而向左滑动会显示第二个和第三个屏幕,分别显示照片图库中的照片和大时钟显示。小部件屏幕由两个并排显示的交互式小部件堆栈组成,您可以独立地上下滑动。这些堆栈就像主屏幕小部件堆栈

如何在iPhone上自定义和编辑待机模式:iOS 17的新功能如何在iPhone上自定义和编辑待机模式:iOS 17的新功能Sep 21, 2023 pm 04:01 PM

待机是iOS17更新中的一项新功能,它提供了一种新的增强方式,可以在手机快速闲置时访问信息。通过StandBy,您可以方便地查看时间、查看即将发生的事件、浏览日历、获取您所在位置的天气更新等等。激活后,iPhone在充电时设置为横向时会直观地进入待机模式。此功能非常适合床头柜等无线充电点,或者在日常任务中离开iPhone充电时。它允许您轻扫待机中显示的各种小部件,以访问来自各种应用程序的不同信息集。但是,您可能希望根据您的偏好和您经常需要的信息修改这些小部件,甚至删除一些小部件。因此,让我们深入

settimeout和setinterval有什么区别settimeout和setinterval有什么区别Aug 15, 2023 pm 02:06 PM

settimeout和setInterval的区别:1、触发时间,settimeout是一次性的,它在设定延迟时间之后执行一次函数,而setinterval是重复性的,它会以设定的时间间隔重复执行函数;2、执行次数,settimeout只执行一次,而setinterval会一直重复执行,直到被取消。

如何解决Java堆栈溢出异常如何解决Java堆栈溢出异常Nov 13, 2023 am 09:35 AM

解决Java堆栈溢出异常的方法有:1、修改代码逻辑,避免无限递归和循环依赖;2、增加Java虚拟机堆栈大小;3、使用尾递归优化;4、使用迭代替代递归;5、使用多线程。Java堆栈溢出异常通常是由于递归调用太深或者循环依赖导致的,当一个函数递归调用自身,并且没有在某一点终止递归,就会导致堆栈溢出。这是因为每次函数调用都会在堆栈中添加一个新的堆栈帧,如果调用太多次,堆栈就会溢出。

堆和栈的区别是什么堆和栈的区别是什么Aug 10, 2023 am 10:12 AM

堆和栈的区别是:1、栈是一种线性数据结构,而堆则是一种树状的数据结构;2、栈的内存分配方式是自动的,而堆的内存分配与释放需要手动管理;3、栈的内存分配速度相对较快,而堆的内存分配速度较慢;4、栈的大小是固定的,而堆的大小可以根据需要进行动态调整;5、栈适用于管理局部变量、函数调用和递归等,而堆适用于需要长时间存储的数据、动态数据结构和大型数据等。

深入探讨Golang中堆栈的差异深入探讨Golang中堆栈的差异Mar 13, 2024 pm 05:15 PM

Golang是一门广受欢迎的编程语言,其在并发编程方面拥有独特的设计理念。在Golang中,堆栈(heap和stack)的管理是一项非常重要的任务,对于理解Golang程序的运行机制至关重要。本文将深入探讨Golang中堆栈的差异,并通过具体的代码示例来展示它们之间的区别和联系。在计算机科学中,堆栈是两种常见的内存分配方式,它们在内存管理和数据存储上有着不同

Java使用StackTraceElement类追踪方法调用堆栈Java使用StackTraceElement类追踪方法调用堆栈Jul 25, 2023 pm 03:21 PM

Java使用StackTraceElement类追踪方法调用堆栈引言:在软件开发中,调试是一个非常重要的过程,它可以帮助我们定位问题并找出错误的根源。而在调试过程中,了解方法调用的堆栈情况可以帮助我们更快地找出问题所在。Java中,我们可以通过使用StackTraceElement类来追踪方法调用堆栈。一、StackTraceElement类介绍:Stack

PHP SPL 数据结构:一个让你的代码焕然一新的工具包PHP SPL 数据结构:一个让你的代码焕然一新的工具包Feb 19, 2024 pm 12:09 PM

PHPSPL数据结构:概述phpSPL数据结构是PHP标准库(SPL)中的一个组件,它提供了一组通用数据结构,包括堆栈、队列、数组和哈希表。这些数据结构经过优化,可高效处理各种数据类型,并提供了一致的接口,简化了应用程序开发。主要数据结构堆栈堆栈是一种遵循后进先出(LIFO)原则的有序集合。在堆栈中,最后一个添加的元素将是第一个被删除的元素。SPL提供了一个SplStack类来表示堆栈。以下示例展示了如何使用SplStack:$stack=newSplStack();$stack->push(1

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热工具

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

mPDF

mPDF

mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

WebStorm Mac版

WebStorm Mac版

好用的JavaScript开发工具

Atom编辑器mac版下载

Atom编辑器mac版下载

最流行的的开源编辑器

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境