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

Javascript高级—闭包问题

闭包问题

循环中赋值为引用的问题

for (var i = 1; i < 5; i++) {setTimeout(function timer() {console.log(i)}, i * 1000)
}

解决方法有3种

第一种,使用立即执行函数方式

for (var i = 1; i < 5; i++) {(fuction(j){setTimeout(function timer() {console.log(j)}, j * 1000)})(i)
}

第二种,使用ES6的let

for (let i = 1; i < 5; i++) {setTimeout(function timer() {console.log(i)}, i * 1000)
}

第三种,使用setTimeout的第三个参数

for (var i = 1; i < 5; i++) {setTimeout(function timer(j) {console.log(j)}, i * 1000, i)
}

计数器

实现一个foo函数 可以这么使用:

a = foo();b = foo();c = foo();
// a === 1;b === 2;c === 3;
foo.clear();d = foo(); //d === 1;
function myIndex() {var index = 1;function foo(){return index++;}foo.clear = function() {index = 1;}return foo;
}var foo = myIndex();
http://www.lryc.cn/news/483321.html

相关文章:

  • C#入门 017 字段,属性,索引器,常量
  • 磐石云语音助手拦截介绍
  • JSP执行过程及其与Servlet执行效率的比较
  • open3d
  • Vue中优雅的使用Echarts的三种方式
  • SpringBoot配置文件/日志
  • 微服务架构面试内容整理-SpringCloud Netflix‌与Spring Cloud Alibaba比较
  • JDBC魔法:连接MySQL数据库与数据操作的秘籍
  • 深入了解Scratch:引导初学者开启编程之旅
  • js复制内容到剪切板
  • 代码 RNN原理及手写复现
  • 企业官网的在线客服,如何提高效果?
  • 「实战应用」如何可视化 DHTMLX Scheduler 中的资源工作量?
  • 论文阅读《BEVFormer》
  • sql专题 之 sql的执行顺序
  • Vue3 -- 基于Vue3+TS+Vite项目【项目搭建及初始化】
  • CTF-RE: TEA系列解密脚本
  • 信号量和线程池
  • 【人工智能】10分钟解读-深入浅出大语言模型(LLM)——从ChatGPT到未来AI的演进
  • 「QT」几何数据类 之 QPointF 浮点型点类
  • 可能是全网第一个MySQL Workbench插件编写技巧
  • D62【python 接口自动化学习】- python基础之数据库
  • 探索美赛:从准备到挑战的详细指南
  • IP地址查询——IP归属地离线库
  • “倒时差”用英语怎么说?生活英语口语学习柯桥外语培训
  • Linux入门攻坚——37、Linux防火墙-iptables-3
  • 微服务架构面试内容整理-安全性-Spring Security
  • 新的服务器Centos7.6 安装基础的环境配置(新服务器可直接粘贴使用配置)
  • 深度学习:广播机制
  • 音视频入门基础:FLV专题(25)——通过FFprobe显示FLV文件每个packet的信息