cari
Rumahhujung hadapan webtutorial jsJavaScript调用堆栈及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函数调用的灵活性,为函数执行顺序的调度提供极大便利。
Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi 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充电时。它允许您轻扫待机中显示的各种小部件,以访问来自各种应用程序的不同信息集。但是,您可能希望根据您的偏好和您经常需要的信息修改这些小部件,甚至删除一些小部件。因此,让我们深入

如何解决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、栈适用于管理局部变量、函数调用和递归等,而堆适用于需要长时间存储的数据、动态数据结构和大型数据等。

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

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

深入探讨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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini