闭包的原理跟作用

简介: 闭包的原理跟作用

闭包及原理

概念

一个函数和对其周围状态(lexical environment,词法环境)的引用捆绑在一起(或者说函数被引用包围),这样的组合就是闭包closure)。大白话也就是说,闭包让你可以在一个内层函数中访问到其外层函数的作用域

function fn() {
  var a = 10
  return function getData() {
    return a
  }
}
var getData = fn()
var a1 = getData()


原理

闭包的原理就是利用作用域链的特性,首先在当前作用域访问数据,当前作用域访问不到,则向父级访问,父级也没有,一直找到全局。


作用

数据私有化,防止污染全局

var a = 10
function fn() {
  console.log(a)
}
console.log(a)

将闭包代码修改后也同样可以访问到 a 数据,但是此时 a 的数据在全局,全局可以直接对 a 数据进行修改,而且全局也多了一个 a 这个数据,要尽量避免直接将数据直接放到全局


缺点

闭包会造成内存泄漏,因为闭包的数据没有被回收

function fn() {
  var a = 10
  return function getData() {
    return a
  }
}
var getData = fn()
var a1 = getData()


解决方案:将全局指向的函数重新置为 null,利用标记清除的特性

function fn() {
  var a = 10
  return function getData() {
    return a
  }
}
var getData = fn()
getData = null



目录
相关文章
|
1月前
|
存储 编译器 C语言
【C语言】函数(涉及生命周期与作用域)
【C语言】函数(涉及生命周期与作用域)
|
2月前
|
缓存 JavaScript 前端开发
了解js基础知识中的作用域和闭包以及闭包的一些应用场景,浅析函数柯里化
该文章详细讲解了JavaScript中的作用域、闭包概念及其应用场景,并简要分析了函数柯里化的使用。
了解js基础知识中的作用域和闭包以及闭包的一些应用场景,浅析函数柯里化
|
3月前
|
自然语言处理 JavaScript 前端开发
什么是闭包,它有什么作用
【8月更文挑战第2天】什么是闭包,它有什么作用
47 9
|
5月前
|
自然语言处理 JavaScript 前端开发
JavaScript闭包是函数访问外部作用域变量的能力体现,它用于封装私有变量、持久化状态、避免全局污染和处理异步操作。
【6月更文挑战第25天】JavaScript闭包是函数访问外部作用域变量的能力体现,它用于封装私有变量、持久化状态、避免全局污染和处理异步操作。闭包基于作用域链和垃圾回收机制,允许函数记住其定义时的环境。例如,`createCounter`函数返回的内部函数能访问并更新`count`,每次调用`counter()`计数器递增,展示了闭包维持状态的特性。
53 5
|
6月前
|
自然语言处理
闭包的工作原理
闭包是函数及其相关引用环境的组合,允许函数在外部调用时仍能访问词法作用域内的变量。当内部函数定义并捕获其创建时的作用域后,即使词法环境销毁,函数仍可通过闭包保持对变量的引用。
|
6月前
|
JavaScript 前端开发
闭包的工作原理是什么?
【1月更文挑战第16天】
48 2
|
6月前
|
自然语言处理 JavaScript 前端开发
JavaScript开发基础问题:如何理解闭包及其作用?
JavaScript开发基础问题:如何理解闭包及其作用?
60 5
|
6月前
|
人工智能 自然语言处理 前端开发
闭包是什么?闭包的用途是什么?
闭包是什么?闭包的用途是什么?
|
自然语言处理 JavaScript 前端开发
JavaScript 实践+理论(总结篇):作用域、闭包、this、对象原型(上)
JavaScript 实践+理论(总结篇):作用域、闭包、this、对象原型
|
前端开发
前端学习案例2-闭包定义2
前端学习案例2-闭包定义2
61 0
前端学习案例2-闭包定义2