美文网首页
2019-06-12 For循环原理

2019-06-12 For循环原理

作者: 倚舟先生 | 来源:发表于2019-06-24 11:14 被阅读0次

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循环还有一个特别之处,就是设置循环变量的那部分是一个父作用域,而循环体内部是一个单独的子作用域。                                                                                                                                                                                 一  阮一峰         

                                                                                                                

相关文章

  • 2019-06-12 For循环原理

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

  • js两个数组进行数据筛选

    原理:使用两个for循环进行循环判断

  • 2018-11-11

    循环神经网络(RNN)原理通俗解释 循环神经网络(RNN)原理通俗解释 - 多元思考力 - CSDN博客 一文搞懂...

  • 组件化,mvvm,循环引用原理,js交互

  • for 循环内部原理

    先上代码: 上述代码也等同于 分析: 1、在遍历Foo的实例对象时,执行for...in...时,首先会先执行it...

  • PDCA循环原理

    PDCA戴明循环,通常用于项目管理、个人管理。 PLAN 计划 DO 执行 CHECK 检查 ACTION 纠正、反馈

  • crontab指定时间执行程序(秒)

    crontab 指定秒执行原理: shell脚本for循环 for语句实现循环指定秒数执行。laravel框架 ...

  • 集合,数组,字典的快速遍历和排序

    遍历 for 循环遍历 原理:通过for循环的循环变量用作数组元素下标来获取不同下标的元素循环次数就是数组元素的个...

  • 如何正确的使用Block

    循环引用(原理) 1.给大家简单的概括一下循环引用出现的原理 A持有B 但是B又强引用A,而A在销毁的时候,就出现...

  • UItableView的cell优化

    tableViewCell的常见设置 TableViewCell的循环使用 循环使用的原理 首先,我们在手机界面的...

网友评论

      本文标题:2019-06-12 For循环原理

      本文链接:https://www.haomeiwen.com/subject/qfslfctx.html