您不需要设置超时时间

我知道计时器已经成为很多人在日常任务中使用的功能一段时间了。在 javascript 世界中,计时器通常使用 settimeout 或 setinterval 函数来实现,如果你这样做的话,坏消息是这不是一个好的做法,我会尝试解释原因。

在开始解释我的想法之前,我有一个问题要问你:你可以使用报错时间的手表吗?

如果您的答案是肯定的,很抱歉浪费了您的宝贵时间,因为这篇文章不属于您。

另一方面,如果你的答案是否定的,我会解释为什么使用 settimeout 或 setinterval 就像使用损坏的手表来获取时间。

这些功能的问题

首先,让我们考虑以下代码片段

 function test() {   let i = 0;   settimeout(() => console.log("hello"), 0);   while (i < 5) {     console.log("number ", i);     i += 1;  }  console.log("world");

如果您在浏览器控制台中运行此代码片段,您将得到以下结果

您不需要设置超时时间

此行为是由于 settimeout 将回调添加到浏览器队列中,以便在空闲时处理它(没有任务要做)换句话说,传递给 settimeout 的回调具有较低的值优先

现在,知道了这一点,我想您将很难使用 settimeout 函数来实现计时器,因为您可以同时有 2 个甚至 10 个刻度(取决于您的浏览器的繁忙程度)。这对于调试来说将是一场噩梦,但是我们有更好的解决方案吗?

避免这些功能的方法

为了提供更好的实现计时器的方法,我们应该使用 requestanimationframe 函数,因为它告诉浏览器在下一次绘制之前执行回调(换句话说,在 ui 发生任何更改之前)

这里的区别非常微妙,所以最好通过代码来理解。让我们收回之前的代码片段并稍微调整一下以比较 settimeout 和 requestanimationframe

function testwithanimationframe() {  let i = 0;  settimeout(() => console.log("hello"), 0);  requestanimationframe(() => console.log("tell me the next paint"));  while (i < 5) {    console.log("number ", i);    i += 1;  }  console.log("world");}

在此示例中,我们可以看到,在 chrome 上运行时,settimeout 在 requestanimationframe 之前运行 (尽管在极少数情况下会发生相反的情况)

您不需要设置超时时间

但是如果你在 firefox 上运行它,这将是输出

您不需要设置超时时间

这看起来可能令人困惑,但如果你稍微注意一下,你会发现执行过程中没有发生任何绘画,因此如何处理这种情况取决于浏览器。

ViiTor实时翻译 ViiTor实时翻译

AI实时多语言翻译专家!强大的语音识别、AR翻译功能。

ViiTor实时翻译 116 查看详情 ViiTor实时翻译

现在,如果我们可以调整代码片段以使浏览器重新绘制页面,让我们看看会发生什么

function testWithAnimationFrame2() {  let i = 0;  setTimeout(() => console.log("hello"), 0);  requestAnimationFrame(() => console.log("tell me the next paint"));  while (i < 5) {    console.log("number ", i);    i += 1;    document.body.style.backgroundColor = "red";  }  console.log("world");}

这是 chrome 上的输出

您不需要设置超时时间

这是 firefox 中的输出

您不需要设置超时时间

正如您在日志中看到的,当浏览器在 ui 中进行更改时,requestanimationframe 函数将始终优先于其他计划的回调。

因为在网络上,我们不断地执行重绘,requestanimationframe 是实现计时器的明显选择。

了解 requestanimationframe 函数

该函数仅接受回调作为参数。为了向回调提供上下文,它应该采用一个时间戳,指示基于页面初始渲染时间的前一帧结束的时间。

该函数将返回一个代表请求标识符的整数,如果您希望使用cancelanimationframe函数取消请求,这会很有用。

javascript 中秒表的简单实现

要实现秒表,有一些要求:

我们应该知道它应该在多少时间后滴答(通常是一秒)我们应该知道秒表停止滴答的延迟时间滴答间隔应该小于延迟

考虑到所有这些要求,以下代码片段将为您创建一个秒表

尾奏

我知道这可能是一篇很长的文章,但相信您会喜欢它。无论如何,如果您有任何疑问或有任何建议,请随时联系我。

感谢您的阅读,再见?

以上就是您不需要设置超时时间的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月8日 04:36:11
下一篇 2025年11月8日 04:37:05

相关推荐

  • 什么是C++中的安装程序?

    c++++中的安装程序不是语言本身的一部分,而是用于部署c++应用的工具。常见的类型包括:1.独立安装程序(如nsis),2.网络安装程序(如wix),3.包管理器(如vcpkg)。创建安装程序需经过准备文件、选择工具、编写脚本、测试和发布等步骤。 C++中的安装程序(Installer)并不是C+…

    2025年12月18日
    000
  • C++中的GUI布局管理器是什么?

    c++++中的gui布局管理器是用于管理和组织gui元素的工具。1) qt使用qboxlayout等类,2) wxwidgets使用wxsizer类。它们使界面布局灵活且易于维护。 C++中的GUI布局管理器是什么? C++中的GUI布局管理器是一种用于管理和组织GUI(图形用户界面)元素的工具,它…

    2025年12月18日
    000
  • 如何实现C++中的跨平台构建?

    c++++中的跨平台构建可以通过使用cmake、autotools、meson等构建系统和sdl、boost等平台抽象库来实现。1. 使用cmake进行条件编译和链接,生成不同平台所需的构建文件。2. 利用sdl或boost简化代码,使其在不同操作系统上保持一致性。3. 进行广泛的测试和调试,确保代…

    2025年12月18日
    000
  • xcode 怎么创建 c++ 项目

    在 xc++ode 中创建 c++ 项目可以通过以下步骤实现:1. 打开 xcode,点击 “create a new xcode project”。2. 选择 “macos” 平台和 “command line tool” 模…

    2025年12月18日
    000
  • clion 怎么创建 c++ 项目

    在 c++lion 中创建 c++ 项目可以通过以下步骤实现:1. 启动 clion 并点击 “create new project”。2. 选择 “c++ executable” 作为项目类型。3. 设置项目位置,建议使用专门文件夹。4. 选择 c+…

    2025年12月18日
    000
  • Gulc:从头开始建造的C库

    本文开启了一个系列,介绍我正在开发的C99库:Gulc(Generic Utility Library的缩写)。该库主要用于学习和娱乐目的,旨在提供C标准库中安全内存管理和实用功能(如向量和无序映射),以简化C语言编程。未来将持续添加更多功能。 目前,该库包含一个简单的验证系统(类似于断言,但在发行…

    2025年12月18日
    000
  • vs 怎么管理多个 c++ 项目

    在 visual studio 中管理多个 c++++ 项目可以通过创建解决方案和使用 cmake 来实现。1. 创建新解决方案并添加 c++ 项目。2. 使用 cmake 管理项目依赖和配置。通过这些方法,可以高效地组织和维护多个 c++ 项目,提升开发效率。 引言 搞 C++ 开发的朋友们,管理…

    2025年12月18日
    000
  • Meson:使用无中造成的GIT项目作为依赖

    meson项目依赖处理:巧妙解决无meson.build文件的git项目依赖问题 许多优秀的Git项目缺乏Meson.build文件,这给使用Meson构建系统的开发者带来了挑战。本文将介绍一种方法,通过创建补丁文件来解决这个问题,并成功将一个没有Meson.build文件的Git项目作为子项目添加…

    2025年12月18日
    000
  • 网络服务安装

    推介会: 本 SAE(业务学习情况)项目旨在开发一个基于客户端-服务器架构的实时“CAT”网络讨论应用程序。该应用允许多个客户端连接到中央服务器并进行实时通信。下图概述了套接字功能: 资源配置: 编程语言:C 语言版本控制:使用分布式 Github 进行代码共享开发环境:Visual Studio …

    2025年12月18日
    000
  • CSS Grid 布局在 IE 中不兼容的原因及解决方案

    IE 不兼容 CSS Grid 布局的原因是它不支持 CSS Grid 规范。解决方案包括:1. 使用 polyfills 模拟现代浏览器功能;2. 切换到支持 CSS Grid 布局的浏览器;3. 使用替代布局技术(如 Flexbox)。 CSS Grid 布局在 IE 中不兼容的原因 CSS G…

    2025年12月18日
    000
  • 探索文件拆分和合并:管理大文件的革命性工具

    您是否曾在传输或存储大量文件时遇到困难?了解 File Splitter & Merger,这是一个开源项目,旨在以优雅和高效的方式简化这一挑战。 这个项目是做什么的? 文件分割和合并由两个工具组成: 文件分割器 — 将大文件分成更小的块。 文件合并 — 将这些块重新组合成原始文件 为什么有…

    2025年12月18日
    000
  • NFetch

    大家好。 我想与你分享我的新项目。最近我了解了 neofetch 项目归档,并决定尝试用 c 语言编写我的模拟。 现在基本功能已经实现,使用flags进行数据输出等 您可以在链接中找到该项目的源代码:https://github.com/nighty3098/nfetch 安装: git clone…

    2025年12月18日
    000
  • 获取下一行学习如何处理文件描述符和系统 I/O 的项目

    在 c 编程领域,有效管理输入、输出和内存是基础。为了帮助您掌握这些关键概念,您将在 get_next_line 项目中编写一个使用文件描述符逐行读取文件的函数。每次调用该函数都会从文件中读取下一行,从而允许您一次一行处理整个文件内容。 了解系统中的文件描述符和 i/o 什么是文件描述符? 文件描述…

    2025年12月18日
    000
  • 使用免费 NET DIO + Randstad 的后端训练营

    免费的 bootcamp coding the future randstad – backend with .net 对于任何想要专注于 c# 编程语言和 microsoft 开发生态系统的人来说都是一个绝佳的机会。 凭借超过 8,000 个奖学金,参与者将有机会学习 .net 基础知识,成为能够…

    2025年12月18日 好文分享
    000
  • 如何为 C++ 函数库函数贡献代码?

    为 c++++ 函数库贡献代码的指南:选择函数库并了解其贡献流程。创建 issue 描述你的问题或功能请求。编写代码更改并创建 pull request。撰写清晰的编码注释。遵循函数库的编码风格。编写测试用例以确保代码正常工作。 如何为 C++ 函数库函数贡献代码 简介 对开源 C++ 函数库进行贡…

    2025年12月18日
    000
  • C++ 函数的库函数的依赖性和版本管理如何处理?

    c++++ 函数的库函数依赖性管理包括静态链接或动态加载,版本管理涉及 abi 版本和源代码版本。通过检查版本号或使用符号链接可以确保兼容性。实战中,需安装库,检查 abi 版本,获取源代码版本,并使用适当的标志编译和链接程序。 C++ 函数的库函数依赖性和版本管理 在 C++ 中,函数通常会依赖于…

    2025年12月18日
    100
  • clion的安装与配置教程

    CLion是一款由JetBrains开发的C/C++ IDE。安装步骤包括:下载并安装CLion、安装CMake、选择工具链。配置步骤包括:导入项目、编译和运行、调试、代码格式化、添加插件。CLion支持多种功能,包括CMake构建、工具链选择、代码格式化、调试和插件扩展。 CLion 安装与配置教…

    2025年12月18日
    000
  • C++ 函数在人工智能中的广泛应用

    c++++ 函数在人工智能中被广泛应用,用于以下任务:分类:将数据分配到类别(如手写数字识别)回归:预测连续值(如预测房屋价格)聚类:将数据点分组到类似组中(如客户细分)特征工程、模型训练、推理和部署 C++ 函数在人工智能中的广泛应用 引言 C++ 是一门强大的编程语言,在人工智能 (AI) 领域…

    2025年12月18日
    000
  • 埃尔凡操作系统

    ErfanOS:全面控制之路 ErfanOS 是 ErfanKeyhani-1 (Me) 的一个定制操作系统项目,旨在摆脱对政府控制和企业运行系统的需求。它是一个完全 DIY 的操作系统,使用自定义程序集引导加载程序启动,在 32 位保护模式 下运行,并具有 基于 C 的内核。您可以在 QEMU 上…

    2025年12月18日
    000
  • clion和vscode哪个好

    哪款 IDE 更胜一筹?入门门槛:VSCode 门槛较低,适合初学者。语言支持:VSCode 支持多种语言,CLion 专注于 C/C++。调试功能:CLion 调试工具更全面。代码补全:两者均提供优秀补全,CLion 专注于 C/C++。版本控制:两者集成良好。价格:VSCode 免费,CLion…

    2025年12月18日
    000

发表回复

登录后才能评论
关注微信