首页
学习
活动
专区
圈层
工具
发布

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

❝小闫语录:我一直在幻想,那些伟大的预言家都来自未来,那些畅销小说家都是真实经历过... ❞ 每天不是在写 bug,就是在解 bug 的路上~更多精彩文章请关注公众号『Pythonnote』或者『全栈技术精选...』 1.问题描述 在一个 for 循环中,我动态给一堆 a 标签绑定 onclick 事件时,发现点击事件不正确。...[i].onclick = function() { alert(i); }; } 我需要的是,点击第一个链接,弹出 0,点击第二个链接,弹出 1......以此类推。...调用时,发现内部没有定义变量 i ,所以就去外面找一下,发现外层有,就取外层的值了,但是为什么是 5 呢?...那是因为 for 循环的结束条件是 i 不满足 ii 的值就是 5,匿名函数到外层取值正好取到了它。

5K10

C语言中循环语句总结

while循坏:  for循环:  while和for循环的对比: 区别:for 和 while 在实现循环的过程中都有初始化、判断、调整这三个部分,但是 for 循环的三个部 分⾮常集中,便于代码的维护...", i); } return 0; } 运行结果: continue:跳过本次循.环中 continue 后的代码,直接去到循环的调整部分。...continue;//这⾥continue跳过了后边的打印,来到了i++的调整部分 printf("%d ", i); } return 0; } 运行结果: 对比for循环和while循环中continue...对代码的运行影响: 分析代码可以知道它们修改条件的位置不同 对于while循环的修改条件在continue后面所以当i=5时,他没法继续修改,而是陷入i=5的死循环  对于for循环的修改条件在continue...上面,所以当i=5时,它会跳出printf函数来到上面进行条件修改,在i=5这个基础上进行i++ do while语句中break和continue的作用跟while一样: goto语句 作用:goto

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

    一篇文章带你了解JavaScript for循环

    语句1在循环开始前设置变量 (var i = 0),语句2定义了循环运行的条件 (i 必须小于 5),语句3增加值(i++) 每次循环中的代码块都已被执行。 1....语句 1 通常,您将使用语句1初始化循环中使用的变量 (i = 0)。语句1是可选的,可以在语句1中初始化多个值(逗号分隔)。...如果省略语句2,则必须在循环中提供一个中断。否则循环永远不会结束。这将使你的浏览器崩溃。 3....语句3也可以省略(例如当你在循环中增加你的值)。...介循环中for循环在实际项目的应用。通过 循环语法讲解,文字的说明。不同种类的循环能够让读者更好的去理解for 循环。 希望能够帮助读者更好的学习。

    58510

    C语言中的分支循环语句(for,while,do...while篇)

    2、for循环 2.1. for循环的语法形式 for(表达式1;表达式2;表达式3;) 语句;//如果循环中想包含多条语句,可以加上大括号 表达式1用于循环变量的初始化 表达式2用于循环结束条件的判断...整个循环的过程中,表达式1初始化部分只被执⾏1次,剩下的就是表达式2、循环语句、表达式3在循 环。...2.3 for循环和while循环的对比 #include int main() { int i=1;//初始化 while(i<=10)//判断 { printf...(i=1;ii++) printf("%d",i) return 0; } for 和 while 在实现循环的过程中都有初始化、判断、调整这三个部分,但是 for 循环的三个部 分⾮...3.2. do...while循环的执行流程  在 do while 循环中先执⾏图上的“语句”,执⾏完语句,在去执⾏“判断表达式”,判断表达式的 结果是!

    9210

    如何根据页面标签自动生成文章目录?分析+代码详解

    遍历文章,很简单,我们使用childNodes方法和foreach循坏即可。 childNodes 属性返回节点的子节点集合,以 NodeList 对象。 实操演示如下。...: [加上id] 之后,在JavaScript内即可获取子元素: // 获取文章内容 const article_content = document.getElementById('content')...首先在循坏遍历的外侧,添加一个数组,如果页面元素标签,在这个数组范围内,就提取到标签集合并生成一个对象丢到titles内: // 哈哈,三级目录差不多了吧。...nodeName: e.nodeName }); 最终代码效果: const article_content = document.getElementById...如果是原生JavaScript,就要自己拼接了…… // 原生JavaScript遍历 for (index in catalog) { document.getElementById('cataLog

    5.7K91

    【javaScript案例】之验证码的实现

    今天的案例,效果如下: 验证码true.gif 这个案例的实现其实没有很多难点,让我们一起来看看吧~ html和css的实现,在这里就不做解释啦,可以比对下面的代码自己实现一下,注意一下细节就好了 接着咱们来看看...js的实现: 我们需要做到的有两点: 实现验证码的随机产生,使其在==页面刷新和点击更换==时能够生成 实现输入字符串和验证码的比较 ==第一点呢==,我们需要用到for循环和Math.round(Math.random...()*n),使得在每一次循环中可以产生随机数字 ==第二点呢==,我们只需要通过input.value来获得用户输入的字符串,然后将其与之前随机产生的字符串进行比较即可(使用===) 其他的细节可以去代码中查看哦...check"); var code; function fun(){ let str=""; for(let i=...0;ii++){ let pos=Math.round(Math.random()*15);//注意这个写法,取随机数 str+=sum

    50140

    Go语言学习(五)| 控制结构

    Go 对于值之间的比较有非常严格的限制,只有两个类型相同的值才可以进行比较,如果值的类型是接口,它们也必须都实现了相同的接口 for循环(没有do或者while)switch和ifselect 类型选择和多路通讯转接器...条件控制 if / else if Go 的 if 还有个强大的地方就是条件判断语句里面允许声明一个变量,这个变量的作用域只能在该条件逻辑块内,其他地方就不起作用了,如下所示: // 计算获取值x,然后根据...(i) i++ if i < 5 { goto Here } } 循环 循环语句是用来重复执行某一段代码。...while(true) 一样(死循环) for {} continue 语句用来跳出 for 循环中当前循环。...在 continue 语句后的所有的 for 循环语句都不会在本次循环中执行。循环体会在一下次循环中继续执行。嵌套循环时,可以再 break 后面指定标签。用标签决定那个循环被终止。

    86920
    领券