当前位置: 首页 > news >正文

for循环中的setTimeout以及var let作用域

看了很多解释,感觉都不好理解。这个文章是我自己的理解,可以做个参考,如果我理解的不对,欢迎在评论区指正:


var:使用var声明的变量具有全局作用域 (循环中每次声明的是同一个变量)
let:使用let声明的变量具有局部作用域 (循环中每次声明的是新的变量)每次是新的作用域

为什么var使用的是同一个呢?因为var可以变量提升,let不可以;

可以把for循环拆解成这样的代码去理解,就通顺了:

for(var i=0;i<2;i++){setTimeout(()=>console.log(i),1000)
}// 相当于
var i;  // 变量提升
function q(){i=0;setTimeout(()=>console.log(i),0)
}
q();function w(){i=1;setTimeout(()=>console.log(i),0)
}
w();function e(){i=2;
}
e();

然后let可以拆解成这样:
 

for(let i=0;i<2;i++){setTimeout(()=>console.log(i),1000)
}// 相当于
function q(){let  i=0; // 变量提升不了setTimeout(()=>console.log(i),0)
}
q();function w(){let i=1;setTimeout(()=>console.log(i),0)
}
w();function e(){let  i=2;
}
e();

 var里面由于改变的都是同一个变量,setTimeout引用的变量地址指向同一个值,所以最后值是相同的。

let里面由于每次都开辟了一个新的内存空间,setTimeout引用的变量地址指向的是不同的值,所以最后值是不同的。

==================================

以上是对let解决方法的语意化,如果使用闭包那么就转化为这样:

for(var i=0;i<2;i++){(function(j){setTimeout(()=>console.log(j),0);})(i)
}var i;  // 变量提升
function q(){i=0;   // 闭包(function(j){setTimeout(()=>console.log(j),0);})(i)
}
q();function w(){i=1;(function(j){setTimeout(()=>console.log(j),0);})(i)
}
w();function e(){i=2;
}
e();

如果说的不对,欢迎指正🎉

http://www.lryc.cn/news/19348.html

相关文章:

  • 有限差分法求解不可压NS方程
  • Android入门第66天-使用AOP
  • pl/sql篇之触发器
  • 黑马《数据结构与算法2023版》正式发布
  • Spring的创建和使用
  • 如何实现外网跨网远程控制内网计算机?快解析来解决
  • 【跟着ChatGPT学深度学习】ChatGPT教我文本分类
  • IM即时通讯架构技术:可靠性、有序性、弱网优化等
  • 【算法】三道算法题两道难度中等一道困难
  • 正交实验与极差分析
  • DEXTUpload .NET增强的上传速度和可靠性
  • SkyWalking 将方法加入追踪链路(@Trace)
  • MySQL Administrator定时备份MySQL数据库
  • Kubernetes入门教程 --- 使用二进制安装
  • 深度学习模型压缩方法概述
  • 《NFL橄榄球》:坦帕湾海盗·橄榄1号位
  • Xmake v2.7.7 发布,支持 Haiku 平台,改进 API 检测和 C++ Modules 支持
  • 苹果ios签名证书的生成方法
  • c++开发配置常用网站记录
  • DC-1 靶场学习
  • oracle 不使用索引深入解析
  • 什么是自助式BI工具,有没有推荐
  • 如何高效管理自己的时间,可以从这几个方向着手
  • 【PAT甲级题解记录】1014 Waiting in Line (30 分)
  • web接入大华摄像头实时视频
  • Git代码冲突-不同分支之间的代码冲突
  • KUKA KR C4机器人与S7-1200PLC进行PROFINET通信的具体方法和步骤
  • 从0到1一步一步玩转openEuler--24 openEuler管理进程-调度启动进程
  • Servlet笔记(10):Session跟踪
  • Hive---分区表和分桶表