首页
学习
活动
专区
工具
TVP
发布
您找到你想要的搜索结果了吗?
是的
没有找到

js的四种for循环

总结一下JavaScript 的 for 循环 写在前面 最近刷题时遇到了几种不同for循环,因为没有深入了解导致做题时无法区分它们的用法,尤其是在以及在使用时的注意点。...因此本文主要对js的四种for循环进行总结区分。 文章最后通过一个面试题加深对不同for循环的认识和使用。...在ECMAScript5(简称 ES5),有三种 for 循环,分别是:· for 、 for-in 、 forEach 在2015年6月份发布的ECMAScript6(简称 ES6),新增了一种循环...所以,鉴于以上种种缺陷,我们需要改进原先的 for 循环。但 ES6 不会破坏你已经写好的 JS 代码。目前,成千上万的 Web 网站依赖 for-in 循环,其中一些网站甚至将其用于数组遍历。...如果想通过修正 for-in 循环增加数组遍历支持会让这一切变得更加混乱,因此,标准委员会在 ES6 增加了一种新的循环语法来解决目前的问题,即 for-of 。

1.7K00

JS 循环链表

循环链表的概念循环链表是一种链表的变体,其中链表的最后一个节点指向链表的头节点,形成一个循环或环状结构。与普通链表不同,循环链表没有明确的结束点。...但是,在链接节点时需要特别注意将最后一个节点的指针指向第一个节点,以形成循环的闭合。循环链表的应用场景包括游戏开发循环列表、轮播图展示、约瑟夫环问题等。...场景应用:循环链表常用于需要循环遍历的场景。例如,在游戏开发,可以使用循环链表来实现循环列表,遍历玩家角色队列;在轮播图或循环播放的场景,可以使用循环链表来管理展示内容的顺序。...实现一个循环列表在 JavaScript 循环链表是一种特殊的链表结构,其中最后一个节点指向头节点,形成一个循环。这种数据结构可以用于处理需要连续循环遍历的场景。...在 append 方法,我们将新节点添加到链表的末尾,并确保最后一个节点指向头节点以形成循环链接。在 traverse 方法,我们从头节点开始遍历链表,直到回到头节点为止。

11210

js事件循环

首先,我们来解释下事件循环是个什么东西: 就我们所知,浏览器的js是单线程的,也就是说,在同一时刻,最多也只有一个代码段在执行,可是浏览器又能很好的处理异步请求,那么到底是为什么呢?...而当主线程执行完栈的所有代码后,它就会检查任务队列是否有任务要执行,如果有任务要执行的话,那么就将该任务放到执行栈执行。如果当前任务队列为空的话,它就会一直循环等待任务到来。...因此,这叫做事件循环。 那么,问题来了。如果任务队列,有很多个任务的话,那么要先执行哪一个任务呢?...其实事件循环做的事情如下: 检查Macrotask 队列是否为空,若不为空,则进行下一步,若为空,则跳到3 从Macrotask队列取队首(在队列时间最长)的任务进去执行栈执行(仅仅一个),执行完后进入下一步...原因:因为一开始js主线程跑的任务就是macrotask任务,而根据事件循环的流程,一次事件循环只会执行一个macrotask任务,因此,执行完主线程的代码后,它就去从microtask队列里取队首任务来执行

18.5K41

JS 事件循环

浏览器执行线程 在解释事件循环之前首先先解释一下浏览器的执行线程: 浏览器是多进程的,浏览器每一个 tab 标签都代表一个独立的进程,其中浏览器渲染进程(浏览器内核)属于浏览器多进程的一种,主要负责页面渲染...,脚本执行,事件处理等 其包含的线程有:GUI 渲染线程(负责渲染页面,解析 HTML,CSS 构成 DOM 树)、JS 引擎线程、事件触发线程、定时器触发线程、http 请求线程等主要线程 关于执行的线程...: 主线程:也就是 js 引擎执行的线程,这个线程只有一个,页面渲染、函数处理都在这个主线程上执行。...上述过程的不断重复就是我们说的 Event Loop (事件循环)。...在事件循环中,每进行一次循环操作称为tick,通过阅读规范可知,每一次 tick 的任务处理模型是比较复杂的,其关键的步骤可以总结如下: 在此次 tick 中选择最先进入队列的任务( oldest task

15.1K10

浅析 JS 的 EventLoop 事件循环(新手向)

只能同步执行肯定是有问题的,所以 JS 有了一个用来实现异步的函数:setTimeout 下面要讲的 Event Loop 就是为了确保 异步代码 可以在 同步代码 执行后继续执行的。...这段代码在 调用栈的运行顺序如下图: ? 这个调用栈其实大家经常会见到,就是在控制台报错的时候,错误信息显示的就是当前时刻调用栈的状态。...,就从 Event Queue 拿出一个任务放入 Call Stack 而 Event Loop 指的就是这一整个圈圈: 它不停检查 Call Stack 是否有任务(也叫栈帧)需要执行,如果没有...,就检查 Event Queue,从中弹出一个任务,放入 Call Stack ,如此往复循环。...(macro task) 和 微任务 (micro task) 了,我们放在下篇再讲~ 参考文章 MDN EventLoop javascript-event-loop understanding-js-the-event-loop

2.2K20
领券