2019-06-12 For循环原理

For循环原理


        我们知道for循环中如果用var定义和用let定义是产生不同的结果的,原因是var是全局定义,let是局部定义。


首先先上一个例子

    var a = [];

    for ( var i = 0; i < 10; i++ ) {

        a[i] = function () {

            console.log(i)

         }

    }

    a[6]();  // 结果是10;  

     为什么是10???    

       因为在for循环的时候, 变量i是var命令声明的,在全局范围内都有效,所以全局只有一个变量i。每一次循环变量i的值都会发生改变,而i的值会保留在内存中,随着i的变化,内存中的i也会跟着变化,因为a[]函数是在for循环后初始化调用的,所以此时的i的值实际上是取了内存中的i。也就是说,所有数组a的成员里面的i,指向的都是同一个i,导致运行时输出的是最后一轮的i的值,也就是 10。


当我们把var 换成let的时候:

    var a = [];

    for ( let i = 0; i < 10; i++ ) {

        a[i] = function () {

            console.log(i)

        }

    }

    a[6]();  // 结果是6;  

    原因:

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

    另外,for循环还有一个特别之处,就是设置循环变量的那部分是一个父作用域,而循环体内部是一个单独的子作用域。                                                                                                                                                                                 一  阮一峰         

                                                                                                                

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 这是16年5月份编辑的一份比较杂乱适合自己观看的学习记录文档,今天18年5月份再次想写文章,发现简书还为我保存起的...
    Jenaral阅读 7,916评论 2 9
  • let 命令 块级作用域 const 命令 顶层对象的属性 global 对象 let 命令 基本用法 ES6 新...
    嘉奇呦_nice阅读 5,530评论 0 2
  • SwiftDay011.MySwiftimport UIKitprintln("Hello Swift!")var...
    smile丽语阅读 9,242评论 0 6
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 8,743评论 0 2
  • 第一章 前端三大语言:HTML(专门编写网页内容)、CSS(编写网页样式)、JS(专门编写网页交互行为) 能简写尽...
    fastwe阅读 4,722评论 0 0