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

每天一个前端小知识 Day 3 - JavaScript 的作用域与闭包

JavaScript 的作用域与闭包


1. 什么是作用域(Scope)?

作用域是变量定义的可访问范围。

分类:

类型说明
全局作用域在任何地方都能访问的变量(如浏览器中 window
函数作用域函数内部定义的变量只能在函数内部访问
块级作用域(ES6)使用 letconst 创建的变量,限制在 {}

示例:

var a = 1; // 全局作用域function foo() {var b = 2; // 函数作用域if (true) {let c = 3; // 块级作用域}console.log(c); // ❌ ReferenceError
}

2. 变量声明与提升(Hoisting)

变量和函数声明会“提升”到当前作用域顶部,但只有 varfunction 会提升,let/const 不会。

console.log(a); // undefined(提升了但未赋值)
var a = 10;console.log(b); // ❌ ReferenceError
let b = 20;

3. 什么是闭包(Closure)?

闭包是函数与其词法作用域的组合。

当函数在其定义的作用域外被调用,仍然可以访问其原始作用域中的变量,这就是闭包。

经典面试例题:

function makeCounter() {let count = 0;return function() {count++;return count;};
}const counter = makeCounter();
console.log(counter()); // 1
console.log(counter()); // 2

此处 count 是在外部函数中定义的变量,返回的匿名函数在执行时依旧能访问它。


4. 闭包的应用场景

应用场景示例或说明
数据缓存利用闭包保存函数状态(如计数器)
模块化开发封装变量,避免全局污染
函数柯里化分步传参
防抖/节流函数闭包保存计时器 ID
创建私有变量JS 没有真正的私有变量,闭包是替代方案

5. 面试常见题目与解答

📌 Q1:如何解释 JavaScript 中的闭包?

答:闭包是函数可以“记住”并访问其定义时的词法作用域,即使这个函数在当前词法作用域之外被调用。


📌 Q2:闭包会造成内存泄漏吗?

答:闭包可能会导致不必要的内存占用,因为其引用的外部变量不会被 GC 回收。只要不手动清理引用或及时释放,确实可能造成内存泄漏。


📌 Q3:如何使用闭包实现一个 once 函数(只执行一次)?

function once(fn) {let called = false;return function(...args) {if (!called) {called = true;return fn.apply(this, args);}};
}

📌 Q4:下列代码输出什么?为什么?

for (var i = 0; i < 3; i++) {setTimeout(() => console.log(i), 1000);
}

答:输出 3、3、3
因为 var 没有块级作用域,setTimeout 延迟执行时,i 已变为 3。

解决方法:使用闭包或 let:

for (let i = 0; i < 3; i++) {setTimeout(() => console.log(i), 1000);
}

6. 如何判断是否形成闭包?

  • 函数返回了另一个函数;
  • 返回的函数访问了外层函数的变量;
  • 外层函数执行完毕后,变量仍可访问。

7. 实战建议

  • 不要滥用闭包,避免难以维护的代码和性能问题;
  • 闭包的变量若长期驻留内存,记得手动清除引用;
  • 使用现代 JS 特性(如 let, const)更容易控制作用域;
  • 推荐搭配调试工具(Chrome DevTools)分析作用域链;

✅ 总结

掌握作用域与闭包不仅是写出高质量 JavaScript 的基础,也是面试中区分中高级开发者的关键技能。理解作用域链、变量提升、闭包生命周期,能帮助你更清晰地分析代码执行过程。

相关文章:

  • C++指针的使用
  • 计算机网络 期末实训 eNSP 校园网
  • AI 在智慧农业领域的 10 大应用:从作物监测到精准营销
  • React前端与React Native移动端开发须知差异
  • NLP学习路线图(四十九):spaCy
  • 第二届图像处理、机器学习与模式识别国际学术会议(IPMLP 2025)
  • 支持 TDengine 的数据库管理工具—qStudio
  • 细说STM32单片机SPI-Flash芯片的FatFS移植
  • Kafka Connect生产实践:性能优化与高可用架构构建
  • 基于深度学习的智能图像增强技术:原理、实现与应用
  • 2024 CKS题库+详尽解析| 5. 日志审计
  • 卷积神经网络(CNN)图像识别基础教程
  • 计算机网络-----详解网络原理TCP/IP(下)
  • UDP访问DNS
  • FPGA基础 -- Verilog语言要素之系统任务和系统函数
  • C++11 User-Defined Literals:从入门到精通
  • java 设计模式_行为型_22模板模式
  • web项目部署配置HTTPS遇到的问题解决方法
  • 【友加畅捷】T1飞跃版账套隐藏设置
  • 数据赋能(280)——过程管理——反馈机制
  • php动态网站开发难吗/站长之家权重查询
  • 企业网站设计文档/百度上怎么免费开店
  • 商丘三合一网站建设/拉新人拿奖励的app
  • 厚街网站建设公司/百度网站大全
  • drupal wordpress网站/网络黄页推广软件哪个好用
  • 网站 建设初步/济南百度竞价代运营