对闭包的理解?
>[success] 我们知道函数内部能直接读取函数外部定义的变量,但是函数外部无法读取函数内部的变量,闭包在我看来,就是提供一种访问函数内部变量的桥梁。
闭包的好处和坏处?
>[success] 使用闭包的好处是提供了访问函数内部变量的方式与避免造成全局变量污染。使用闭包的坏处是会造成内存消耗大,滥用闭包会导致内存泄露,造成页面奔溃。
为什么使用闭包会造成内存泄露吗?
>[success] 函数的作用域链是在函数定义的时候创建的,在函数运行完成,销毁的时候消亡,这时它内部的变量就应该被销毁,内存被回收,但是闭包能让其继续延续下去,不被垃圾回收机制回收。由于变量都是维护在内存中的,这些变量数据就会一直占用着内存,最后超载使用内存,造成内存泄露。
闭包的例子:
```
var btn = document.getElementById('btn');
var inputs = document.getElementsByTagName('input');
for(var i = 0;i<inputs.length;i++) {
(function(i) {
inputs[i].onclick = function() {
console.log(i)
}
})(i)
}
```
[内容转载于掘金](https://juejin.cn/post/6979778428505423886#heading-4)
- HTML,CSS
- 如何书写高效的css样式
- box-shadow
- 表格合并行列
- 自适应单位
- 隐藏元素
- 浏览器缓存
- 浏览器内核
- css和js的合理走位
- 2021样式问题汇总
- 模拟面试
- 移动端适配问题
- flexible(rem)
- vw+rem
- 判断一个属性是对象的私有属性
- px rpx em rem vw
- 清除浮动
- 栅格系统
- get&&post
- 雪碧图
- new操作符
- call apply bind区别
- 前端模块化
- 回调函数
- 回调地狱(封装版)
- 回调地狱(promise)
- 回调地狱(generator)
- 回调地狱(async)
- es6新特性
- let
- 箭头函数
- 展开 解构 默认赋值
- vue生命周期
- axios封装
- axios跨域拿数据
- ajax封装
- JavaScript
- 数组
- 排序
- 取偶数
- 反转排序
- 取最大值
- 数组去重
- 复杂版
- 数组的克隆(深拷贝)的方法
- 求质数
- 原型和原型链
- 创建对象
- 什么是路由
- SASS
- jQuery中的append和prepend区别?
- css动画及js动画的区别
- 隐式类型转换
- 原型
- 事件传播
- 函数
- 增加属性
- 构造函数
- 一元操作符
- 作用域
- 短语
- Vue
- - nextTick
- 自我介绍
- 哦豁(;д;)
- for in效果
- 事件
- promise特点
- 如何实现一个ajax请求
- 媒体查询
- substr和substring
- MVC、MVVM
- 面向对象
- 取数据、渲染数据
- ajax
- vue
- React
- es6-class
- 几种类型的DOM节点
- js同源策略
- 闭包
- 2021
- 数据类型
- 闭包2
- 防抖节流
- 原型与原型链
- call与apply与bind
- 深浅拷贝
- New关键字
