首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

For循环中,只能`i++`或者`++i`吗?

var count=0; var count1=1; for(var i=1;i<=99;i+2){ count+=i; } document.write("1~99中的奇数的和是"+count...很明显,这是死循环了,但是不应该啊,难道是i+2的问题? 于是搜索过后,恍然大悟。 因为i++,是有自加功能的,它的含义是i=i+1的缩写,它有两层含义,一是i+1,二是把得到的值再复赋值给i。...而单纯一个i+1没有赋值功能,加完以后,i的值还是原值,加上1,毫无意义。 一般的c语言程序,碰到你写的i+1或者是sum+1这样的式子,代码都会正常运行而不会报错,只是达不到预期的目的而已。...i++不是单纯+1,他存在了一个过程,i = i + 1,而这样就不是直接赋值。 至于为什么i + 2不行,因为他是一步到位,循环中这样i的值是没有任何变化的!...+2确实是+了,只是值还没到位,循环就开始,值没变化,始终为原始值,于是死循环

60110
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    js动态绑定事件,无法使用for循环中变量i的问题

    . ❞ 每天不是在写 bug,就是在解 bug 的路上~更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选』 1.问题描述 在一个 for 循环中,我动态给一堆 a 标签绑定 onclick...[i].onclick = function() { alert(i); }; } 我需要的是,点击第一个链接,弹出 0,点击第二个链接,弹出 1......以此类推。...但是上述代码点击每一个链接总是弹出一个值,而且还是个不正常的值。之所以说它不正常,是因为上面我获取到了 5 个标签,正常下标应该到 4 结束,但是总是弹出 5 ????...答:那是因为事件函数是一个匿名函数,此函数会在 for 循环执行之后调用。调用时,发现内部没有定义变量 i ,所以就去外面找一下,发现外层有,就取外层的值了,但是为什么是 5 呢?...那是因为 for 循环的结束条件是 i 不满足 i<5 ,那么结束后变量 i 的值就是 5,匿名函数到外层取值正好取到了它。

    3.9K10

    js事件循环

    首先,我们来解释下事件循环是个什么东西: 就我们所知,浏览器的js是单线程的,也就是说,在同一时刻,最多也只有一个代码段在执行,可是浏览器又能很好的处理异步请求,那么到底是为什么呢?...从上图我们可以看出,js主线程它是有一个执行栈的,所有的js代码都会在执行栈里运行。...其实(正如上图所示),js是有两个任务队列的,一个叫做Macrotask Queue(Task Queue),一个叫做Microtask Queue 前者主要是进行一些比较大型的工作,常见的有setTimeout...microtask任务会在当前事件循环周期内执行,而新增的macrotask任务只能等到下一个事件循环才能执行了(一个事件循环只执行一个macrotask) 首先,我们先来看一段代码 console.log...原因:因为一开始js主线程中跑的任务就是macrotask任务,而根据事件循环的流程,一次事件循环只会执行一个macrotask任务,因此,执行完主线程的代码后,它就去从microtask队列里取队首任务来执行

    18.8K41

    JS 循环链表

    ---导文循环链表是一种特殊的链表数据结构,其中最后一个节点指向链表的头节点,形成一个循环的环状结构。与普通链表不同,循环链表没有明确的结束点,可以通过任意节点开始遍历整个链表。...循环链表的概念循环链表是一种链表的变体,其中链表中的最后一个节点指向链表的头节点,形成一个循环或环状结构。与普通链表不同,循环链表没有明确的结束点。...但是,在链接节点时需要特别注意将最后一个节点的指针指向第一个节点,以形成循环的闭合。循环链表的应用场景包括游戏开发中的循环列表、轮播图展示、约瑟夫环问题等。...注意环形链表的处理:循环链表在操作时需要特别注意处理环形情况,以避免出现无限循环或死循环的情况。在编程实现中,需要确保正确设置最后一个节点的指针指向头节点。...实现一个循环列表在 JavaScript 中,循环链表是一种特殊的链表结构,其中最后一个节点指向头节点,形成一个循环。这种数据结构可以用于处理需要连续循环遍历的场景。

    14910

    JS数组at函数(获取最后一个元素的方法)介绍

    本文介绍js中数组的at函数,属于比较简单的知识普及性文章,难度不大。 0x00 首先,我们可以思考如下一个问题,如果要获取一个数组的最后一个元素(这是很常用的操作),我们应该怎么做?...当然除了这种方式之外,还有其他的方式,比如: let last = array.slice(-1)[0] 先通过slice获取后面一个元素的数组,然后通过下标0获取最后一个元素。...在比如通过pop获取最后一个元素: let last = array.pop() 但是 通过pop的方式会改变数组本身,所以一般不建议用。 0x01 无论试用上面那种方式,都感觉很繁琐。...这就让人羡慕python里面的数组操作,可以通过负索引的方式获取最后一个元素,代码如下: last = array[-1] js里面不支持负索引的方式。...不过es6新增了一个at方法,可以获取数组的指定索引的元素,并且支持负索引。负索引从后往前计算,-1表示最后一个,-2 表示倒数第二个,依此类推。 因此试用此方法获取最后一个元素会变得简单很多。

    4.7K30

    js跳出for循环

    for循环和forEach循环中中断和继续循环有些不一样的要注意 const list = ['a', 'b', 'c'] for (let i = 0; i < list.length; i++)...(value) if (value === 'b') { break } } 注意:无法中断forEach循环,因此如果需要跳出循环,请使用for或for..of。...如何跳出for双重循环 但是当我们使用了多层for循环的时候,使用continue和break就无法跳出外层的循环了,所以我们需要使用一些技巧,来跳出外层循环。...} } 2、定义一个字段用来判断什么时候跳出外层循环 var array = [1,2,3,4,5]; var flag = false; // 为true时说明需要跳出外层循环 for...3、当循环语句写在函数中时直接用return语句终止双重循环 var array = [1,2,3,4,5]; var func = function() { for (let i = 0; i

    13.4K00

    JS 事件循环

    浏览器执行线程 在解释事件循环之前首先先解释一下浏览器的执行线程: 浏览器是多进程的,浏览器每一个 tab 标签都代表一个独立的进程,其中浏览器渲染进程(浏览器内核)属于浏览器多进程中的一种,主要负责页面渲染...: 主线程:也就是 js 引擎执行的线程,这个线程只有一个,页面渲染、函数处理都在这个主线程上执行。...上述过程的不断重复就是我们说的 Event Loop (事件循环)。...宏任务主要包含:script( 整体代码)、setTimeout、setInterval、I/O、UI 交互事件、setImmediate(Node.js 环境) 微任务主要包含:Promise、MutaionObserver...最后最后,记住,JavaScript 是一门单线程语言,异步操作都是放到事件循环队列里面,等待主执行栈来执行的,并没有专门的异步执行线程。

    15.4K10
    领券