热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

es6let和varfor循环里定义变量

vara[];for(vari0;i

var a = [];
for (var i &#61; 0; i <10; i&#43;&#43;) {a[i] &#61; function () {console.log(i);};
}
a[6](); // 10

解读&#xff1a;

a是一个数组&#xff0c;a的每一项都是一个函数function(){console.log(i);},

变量i是var声明的&#xff0c;是一个全局变量&#xff0c;而数组a的函数内部的console.log(i)&#xff0c;里面的i指向的就是全局的i。也就是说&#xff0c;所有数组a的成员里面的i&#xff0c;指向的都是同一个i&#xff0c;导致运行时输出的是最后一轮的i的值&#xff0c;也就是 10

函数只有调用才会起作用&#xff0c;调用的时候i已经是10了&#xff0c;无论调用数组里边的哪个函数都是输出10

为什么是10 不是9呢&#xff1f;因为在循环中 i&#61;9时 9<10 i执行了一个i&#43;&#43; 为10

var a &#61; [];
for (let i &#61; 0; i <10; i&#43;&#43;) {a[i] &#61; function () {console.log(i);};
}
a[6](); // 6

解读&#xff1a;

变量i是用let声明的&#xff0c;声明的变量仅在块级作用域内有效&#xff0c;外部函数不能访问&#xff0c;所以当前的i只在本轮循环有效&#xff0c;所以每一次循环的i其实都是一个新的变量,所以 a[1]() 只在i&#61;1这轮循环内有效, a[2]()只在i&#61;2这轮循环内有效,所以 a[6]()输出6

变量i是let声明的&#xff0c;当前的i只在本轮循环有效&#xff0c;所以每一次循环的i其实都是一个新的变量&#xff0c;所以最后输出的是6。你可能会问&#xff0c;如果每一轮循环的变量i都是重新声明的&#xff0c;那它怎么知道上一轮循环的值&#xff0c;从而计算出本轮循环的值&#xff1f;这是因为 Javascript 引擎内部会记住上一轮循环的值&#xff0c;初始化本轮的变量i时&#xff0c;就在上一轮循环的基础上进行计算。

for (var i &#61; 0; i <5; i&#43;&#43;) {setTimeout(function(){console.log(i);},1000);
}console.log(i);

先打印一个5 1秒钟后再打印出5个5

因为 for 循环会先执行完&#xff08;同步优先于异步优先于回调&#xff09;,for循环执行的时候 i&#61;4时 i<5 执行 i&#43;&#43;&#xff0c;i为5&#xff0c; 当i&#61;5时 &#xff0c;i不小于5&#xff0c; 所以不执行i&#43;&#43;&#xff0c; 所以for循环执行完的时候i最终为5

setTimeout是异步执行的&#xff0c;1秒后向任务队列里添加一个任务&#xff0c;只有主线上的全部执行完才会执行任务队列里的任务&#xff0c;所以当主线程for循环执行完之后 i 的值为5&#xff0c;这个时候再去任务队列中执行任务&#xff0c;i全部为5&#xff1b;

每次for循环的时候setTimeout都会执行&#xff0c;但是里面的function则不会执行被放入任务队列&#xff0c;因此放了5次&#xff1b;for循环的5次执行完之后不到1秒&#xff1b;

1秒后全部执行任务队列中的函数&#xff0c;所以就是输出五个5啦

for (let i &#61; 0; i <5; i&#43;&#43;) {setTimeout(function(){console.log(i);//0,1,2,3,4},1000);
}console.log(i);//i is not defined

因为let i 的是区块变量&#xff0c;每个i只能存活到大括号结束&#xff0c;并不会把后面的for循环的 i 值赋给前面的setTimeout中的i&#xff1b;而var i 则是局部变量&#xff0c;这个 i 的生命周期不受for循环的大括号限制&#xff1b;



推荐阅读
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • FineReport平台数据分析图表显示部分系列接口的应用场景和实现思路
    本文介绍了FineReport平台数据分析图表显示部分系列接口的应用场景和实现思路。当图表系列较多时,用户希望可以自己设置哪些系列显示,哪些系列不显示。通过调用FR.Chart.WebUtils.getChart("chartID").getChartWithIndex(chartIndex).setSeriesVisible()接口,可以获取需要显示的系列图表对象,并在表单中显示这些系列。本文以决策报表为例,详细介绍了实现方法,并给出了示例。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • 一、什么是闭包?有什么作用什么是闭包闭包是定义在一个函数内部的函数,它可以访问父级函数的内部变量。当一个闭包被创建时,会关联一个作用域—— ... [详细]
  • 本文详细解析了JavaScript中相称性推断的知识点,包括严厉相称和宽松相称的区别,以及范例转换的规则。针对不同类型的范例值,如差别范例值、统一类的原始范例值和统一类的复合范例值,都给出了具体的比较方法。对于宽松相称的情况,也解释了原始范例值和对象之间的比较规则。通过本文的学习,读者可以更好地理解JavaScript中相称性推断的概念和应用。 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • javascript  – 概述在Firefox上无法正常工作
    我试图提出一些自定义大纲,以达到一些Web可访问性建议.但我不能用Firefox制作.这就是它在Chrome上的外观:而那个图标实际上是一个锚点.在Firefox上,它只概述了整个 ... [详细]
  • Voicewo在线语音识别转换jQuery插件的特点和示例
    本文介绍了一款名为Voicewo的在线语音识别转换jQuery插件,该插件具有快速、架构、风格、扩展和兼容等特点,适合在互联网应用中使用。同时还提供了一个快速示例供开发人员参考。 ... [详细]
  • 计算机存储系统的层次结构及其优势
    本文介绍了计算机存储系统的层次结构,包括高速缓存、主存储器和辅助存储器三个层次。通过分层存储数据可以提高程序的执行效率。计算机存储系统的层次结构将各种不同存储容量、存取速度和价格的存储器有机组合成整体,形成可寻址存储空间比主存储器空间大得多的存储整体。由于辅助存储器容量大、价格低,使得整体存储系统的平均价格降低。同时,高速缓存的存取速度可以和CPU的工作速度相匹配,进一步提高程序执行效率。 ... [详细]
  • 闭包一直是Java社区中争论不断的话题,很多语言都支持闭包这个语言特性,闭包定义了一个依赖于外部环境的自由变量的函数,这个函数能够访问外部环境的变量。本文以JavaScript的一个闭包为例,介绍了闭包的定义和特性。 ... [详细]
  • Oracle优化新常态的五大禁止及其性能隐患
    本文介绍了Oracle优化新常态中的五大禁止措施,包括禁止外键、禁止视图、禁止触发器、禁止存储过程和禁止JOB,并分析了这些禁止措施可能带来的性能隐患。文章还讨论了这些禁止措施在C/S架构和B/S架构中的不同应用情况,并提出了解决方案。 ... [详细]
  • 本文记录了在vue cli 3.x中移除console的一些采坑经验,通过使用uglifyjs-webpack-plugin插件,在vue.config.js中进行相关配置,包括设置minimizer、UglifyJsPlugin和compress等参数,最终成功移除了console。同时,还包括了一些可能出现的报错情况和解决方法。 ... [详细]
  • 本文讨论了编写可保护的代码的重要性,包括提高代码的可读性、可调试性和直观性。同时介绍了优化代码的方法,如代码格式化、解释函数和提炼函数等。还提到了一些常见的坏代码味道,如不规范的命名、重复代码、过长的函数和参数列表等。最后,介绍了如何处理数据泥团和进行函数重构,以提高代码质量和可维护性。 ... [详细]
  • 使用eclipse创建一个Java项目的步骤
    本文介绍了使用eclipse创建一个Java项目的步骤,包括启动eclipse、选择New Project命令、在对话框中输入项目名称等。同时还介绍了Java Settings对话框中的一些选项,以及如何修改Java程序的输出目录。 ... [详细]
author-avatar
拍友2602924913
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有