计时器

计时器

JavaScript计时器让您能够在指定时间执行代码,或以固定间隔重复执行。主要有两种计时器:setTimeout()setInterval()。两者都用于安排代码在延迟后运行,但行为有所不同。

setTimeout()

setTimeout() 在指定的延迟后仅执行一次函数或代码块。

工作原理: 告诉JavaScript“等待一段时间后,再执行这段代码”。

语法:

setTimeout(function, delay, ...args);

示例:

function sayHello() {  console.log("Hello, world!");}// 3秒后调用 sayHello() (3000毫秒)setTimeout(sayHello, 3000);

在这个例子中,sayHello 函数会在3秒后执行。setTimeout() 接受两个参数:

要执行的函数 (sayHello)。

延迟时间,单位为毫秒 (3000毫秒 = 3秒)。

...args (可选): 传递给函数的其他参数。

要点:

非阻塞: setTimeout() 不会阻塞其他代码的执行。JavaScript在等待超时期间继续执行其他语句。

毫秒: 延迟以毫秒为单位,最小延迟为1毫秒。

单次执行: 回调函数只会在指定时间后调用一次。

setInterval()

setInterval() 以指定的间隔(毫秒)重复执行代码块或函数,直到手动停止。

工作原理: 告诉JavaScript“每隔一段时间就执行这段代码”。

语法: (语法与setTimeout类似,只是功能不同)

示例:

function sayHelloAgain() {  console.log("Hello again!");}// 每2秒调用 sayHelloAgain() (2000毫秒)setInterval(sayHelloAgain, 2000);

这里,setInterval() 内部的代码会每2秒执行一次。

要点:

非阻塞: 类似于 setTimeout()setInterval() 也是非阻塞的。浏览器在等待下一个间隔时继续执行其他任务。

重复执行: 与只执行一次的 setTimeout() 不同,setInterval() 会以指定间隔持续执行回调函数。

手动停止: 该函数会持续运行,直到使用 clearInterval() 手动停止。

清除计时器

您可以使用 clearTimeout()clearInterval() 来停止计时器。

停止 setTimeout() 计时器:

如果想在执行前取消超时,可以使用 clearTimeout()

function sayHello() {  console.log("Hello, world!");}const timeoutId = setTimeout(sayHello, 4000);// 在执行前停止超时clearTimeout(timeoutId);

停止 setInterval() 计时器:

const intervalId = setInterval(sayHello, 1000);// 5秒后停止间隔setTimeout(() => {  clearInterval(intervalId);  console.log("Interval timer stopped");}, 5000);

这里,我们首先启动一个每秒执行的间隔。然后,5秒后,我们使用 setTimeout()clearInterval(intervalId) 来停止间隔。

关键概念总结:

setTimeout():在指定的延迟后执行一次函数。setInterval():以指定的间隔重复执行函数。clearTimeout() / clearInterval():用于取消计时器。异步特性: 计时器不会阻塞其他代码的执行;它们会被添加到事件队列中,并在调用堆栈为空时执行。精度: 由于繁重的计算或浏览器限制等因素,计时器的精度无法保证。

以上就是计时器的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1501197.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 23:21:33
下一篇 2025年12月19日 23:21:38

相关推荐

  • 了解黑匣子测试:通过Kepothing提高软件质量

    黑盒测试是软件测试中一项关键技术,它通过验证软件功能是否符合预期来确保应用程序质量。测试人员无需了解内部代码,而是专注于输入和输出结果的验证。 什么是黑盒测试? 黑盒测试是一种软件测试方法,测试人员完全不了解软件内部结构和代码。测试的重点是评估软件的功能是否满足需求规格说明书中定义的功能。 黑盒测试…

    2025年12月19日
    000
  • 边缘零信任(第1部分)

    利用JSON Web令牌 (JWT) 安全验证请求:详解及实践 本文将深入探讨json web令牌 (jwt) 的工作机制,以及如何在实际应用中利用其进行安全可靠的请求验证。jwt凭借其安全性与便捷性,已成为现代应用中身份验证和授权的热门选择。 一、JWT 结构与组成 JWT由三个部分组成: Hea…

    2025年12月19日
    000
  • 为什么您应该避免在REACT中避免使用危险的lysetinnerhtml?

    React 中的 属性允许开发者直接设置元素的 innerHTML 属性,无需任何消毒处理。 将不可信的用户输入直接插入此属性极其危险,可能导致严重的跨站脚本 (XSS) 安全漏洞。因此,应始终避免将不可信的用户输入传递给 dangerouslySetInnerHTML 属性。 最佳实践是完全避免使…

    2025年12月19日
    000
  • 货币化开源:可持续发展策略

    开源软件已彻底改变了科技领域,推动了创新、协作和透明度。然而,许多开发者和组织仍然面临着开源项目财务可持续性的巨大挑战。本文探讨了多种开源项目盈利策略,并参考了开放薪酬令牌许可证(OCTL)白皮书。 引言 开源项目的货币化是指在保持开放性和社区合作原则的同时,寻找创收途径。有效的货币化策略能够确保项…

    2025年12月19日
    000
  • 花园团体

    代码创作历程 (2024年12月) 第一部分:区域识别算法 初始目标是将字符网格转换为一个数据结构,该结构能有效地表示每个字符的所有连续区域。我首先尝试了一种基于字典的方法,但很快发现它在处理多个区域时存在局限性。这种方法难以追踪并正确分配属于同一字符的多个不相连区域的单元格。 我尝试了两种不同的方…

    2025年12月19日
    000
  • 使用DS:逐步指南将数据转换为交互式视觉故事

    曾经被枯燥的电子表格束缚,渴望更生动的表达方式吗? 我也有过同样的感受,直到我发现了D3.js。当初,面对原始数据的挑战,我尝试创建简单的交互式图表,这一尝试不仅改变了我对数据可视化的理解,也彻底改变了我此后传递洞察力的方式。今天,我将分享如何利用D3.js制作引人入胜的动态交互式图表,让您的数据不…

    2025年12月19日
    000
  • 如何在双子座AI中生成结构化输出(JSON,YAML)

    本文介绍如何使用google gemini api快速生成高质量的api文档,并演示如何灵活地输出json或yaml格式的结果。作者shrijith venkatrama,hexmos创始人,分享了liveapi的构建过程,这是一个通过代码生成api文档的强大工具。 步骤1:获取Gemini API…

    2025年12月19日
    000
  • 让&#s去看

    vue.js:构建用户界面的高效javascript框架 Vue.js是一个开源的JavaScript框架,用于构建用户界面和单页应用程序(SPA)。由Evan You于2014年创建,它结合了HTML、CSS和JavaScript,提供基于组件的构建方式,适用于各种复杂程度的项目。 import …

    2025年12月19日
    000
  • Beta测试解释了:重要性,过程以及Kepothing如何增强它

    在快节奏的软件开发领域,Beta测试是确保产品质量的关键环节,它连接了开发阶段和最终发布,为开发者提供来自真实用户的宝贵反馈。 什么是Beta测试? Beta测试是软件开发流程中一个重要的阶段,在这个阶段,产品会被发布给特定用户群体进行测试,以发现潜在的错误、收集用户反馈,并确保产品在正式发布前达到…

    2025年12月19日
    000
  • 管理复杂的前端应用程序:经验教训(以及我为帮助的工具)

    大型前端应用的管理一直是开发中的难题,尤其是在处理众多功能及其相互依赖关系时。依赖项管理、启动顺序、特性切换和条件模块等问题,常常导致代码混乱不堪。 我最近发现现有工具已无法满足需求,因此,我开发了一个新的工具:app-compose。 它并非一个新的框架或状态管理器,而是一个轻量级的系统,用于: …

    2025年12月19日
    000
  • Junit vs testng:全面比较

    Java测试框架的选型:JUnit vs. TestNG,以及Keploy集成 在Java开发中,JUnit和TestNG是两种常用的测试框架,各有优劣。选择合适的框架对代码质量、性能优化和开发效率至关重要。本文将深入比较两者的差异、共同点以及与Keploy的集成方案,助您做出明智的选择。 JUni…

    2025年12月19日
    000
  • 如何使用Express和Nodejs发送电子邮件

    使用自定义模板个性化电子邮件发送 我最近在shiksha团队参与了一个项目,需要使用自定义模板向客户发送个性化电子邮件。本文将分享如何使用不同模板自定义电子邮件发送流程的经验。 创建电子邮件模板 项目中使用Nodemailer发送电子邮件。最初,我直接在sendmail函数中使用简单的HTML和CS…

    2025年12月19日 好文分享
    000
  • 爪装置

    代码日历2024年第13天 第1部分 big gulp:每个置换? 又一个令人头疼的最短路径挑战。 所幸,给定的约束条件使问题看起来可解:最多100次按键 – 这意味着如果存在解,它就存在于10,000个排列中的一个:100 * 100 = 10,000;输入中每台机器用3行(加1行空行…

    2025年12月19日
    000
  • 使用JavaScript和Posttresql构建游戏

    重温经典:开源免费的在线笨拙游戏 成为软件开发者是一段充满意义的旅程。我喜欢创造酷炫的东西,而我的业余项目通常都是为了解决我遇到的问题。我的家人一直热衷于一款流行的文字游戏——笨拙。如今,兄弟姐妹们都搬离了家,我们很难像以前那样经常一起玩游戏。为了解决这个问题,我决定重新制作这款深受喜爱的游戏,并将…

    2025年12月19日 好文分享
    000
  • 反应中化合物组件的高级图案:用上下文和克隆构建灵活的UI

    在React中构建复杂的UI时,复合组件模式是一种强大的工具。它允许创建相互协作的组件,从而提供灵活且直观的API。本文将探讨如何使用React的上下文API和cloneElement来设计复合组件,并通过构建灵活的选项卡和手风琴组件来演示其应用。 什么是复合组件? 复合组件是一种设计模式,其中父组…

    2025年12月19日
    000
  • 精神联系的力量:如何增强您的思想,身体和灵魂

    探索内在的宁静:什么是精神联系? 精神联系是指你内在的自我与宇宙、自然或更高力量之间深刻而真实的连接。它超越了宗教信仰的范畴,关乎于寻找内心的平静、人生目标以及与周围世界和谐统一的感觉。 人们寻求精神联系来提升生活品质,缓解压力,并增强自我认知。无论是通过冥想、祈祷还是正念练习,培养你的精神层面都能…

    2025年12月19日
    000
  • nodejs中的类型查看实验性打字稿执行

    关注我的GitHub新项目! 简介 Node.js 23版本引入了一项令人兴奋的实验性功能:直接运行TypeScript文件,无需预编译。此功能简化了开发流程,让开发者像运行JavaScript文件一样轻松运行TypeScript脚本。本文将深入探讨这项实验性功能的工作机制、Node.js 23中的…

    2025年12月19日
    000
  • 使用Realm数据库构建React本地应用

    引言 在React Native应用中高效管理本地数据至关重要。Realm是一个高性能移动数据库,提供流畅的数据存储和检索体验。本文将指导您如何使用@realm/react将Realm集成到React Native项目中,实现数据的创建、读取、更新和删除。 项目设置 首先,安装必要的依赖项: yar…

    2025年12月19日
    000
  • 反应useoptimistic钩子故障

    react 的useoptimistic 钩子:提升用户体验的利器 React 持续改进,不断引入新方法和钩子来优化开发体验。其中,useOptimistic 钩子尤其吸引人。本文将探讨其最佳应用场景,并通过一个例子演示其使用方法。 我最初对useOptimistic 的最佳应用场景感到困惑。直到最…

    2025年12月19日
    000
  • Web可访问性NIMA?

    网络无障碍(通常缩写为A11Y)是指设计网站和网络应用程序,确保所有人,包括残障人士,都能平等地访问和使用。这包括视觉、听觉、运动和认知障碍人士。 为什么要关注网络无障碍? 包容性: 让每个人都有机会获取数字信息。法律合规: 许多国家和地区都有关于网站可访问性的法律法规(例如WCAG,ADA)。SE…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信