1、闭包:闭包就是作用域的延伸
    解释:函数内部的作用域属于局部作用域,导致只有函数内部才可以访问声明的变量。而闭包可以将局部作用域延伸,使其在函数外部也可以访问内部声明的变量等。
    2、变量的作用域
    js变量的作用域无非就两种 局部变量全局变量
    3、JavaScript在函数内部可以访问全局变量

    1. var n = 0;//全局变量
    2. function f1() {
    3. console.log(n)//0
    4. }
    5. f1();

    而在函数内部声明的局部变量,外部无法直接访问

    1. function f1(){
    2. var n=0;//局部变量
    3. //需要注意的是一定要使用var关键字声明才会是局部变量
    4. //若直接 n=0; n则是一个全局变量,外部可以访问
    5. }
    6. console.log(n)//n is not defined

    4、此时思考一个问题,怎么样才能在外部访问函数内部的局部变量??
    此时闭包的作用就体现出来了,看下方例子

    1. function f1() {
    2. var n = 0;
    3. // 此时f2函数就是闭包
    4. function f2() {
    5. return n
    6. }
    7. return f2()
    8. }
    9. let n1 = f1();
    10. console.log(n1)//0

    5、f1是f2的父级,所以在f2中可以访问f1中的局部变量,那么转换一下思路,通过 f2函数 将变量return出来,这样不就可以在f1函数的外部访问内部变量了。

    闭包就是能够读取其他函数内部变量的函数
    闭包基本上就是一个函数内部返回一个函数
    好处
    可以读取函数内部的变量
    将变量始终保持在内存中
    可以封装对象的私有属性和私有方法
    坏处
    比较耗费内存、使用不当会造成内存溢出的问题

    所有的函数都有prototype属性(原型)
    所有的对象都有proto属性
    在Javascript中,每个函数都有一个原型属性prototype指向自身的原型,
    而由这个函数创建的对象也有一个proto属性指向这个原型,
    而函数的原型是一个对象,所以这个对象也会有一个proto指向自己的原型,
    这样逐层深入直到Object对象的原型,这样就形成了原型链。