ES6 闭包

闭包

一、变量作用域

变量根据作用域的不同分为两种:全局变量和局部变量。

  1. 函数内部可以使用全局变量。
  2. 函数外部不可以使用局部变量。
  3. 当函数执行完毕,本作用域内的局部变量会销毁。
二、闭包的概念
  • **闭包函数:**声明一个在函数中的函数,有权访问另一个函数作用域中变量,叫做闭包函数。(函数嵌套函数)
  • **闭包:**内部函数总是可以访问其所在的外部函数中声明的参数和变量,即使在其外部函数被返回(寿命终结)了之后。
  • **闭包的主要作用:**延伸了变量的作用范围。

演示:

从外部访问函数内部的变量

三、闭包的特点
  • 让外部访问函数内部变量成为可能;
  • 局部变量会常驻在内存中,不会被垃圾回收机制回收;
  • 可以避免使用全局变量,防止全局变量污染;
  • 会造成内存泄漏(有一块内存空间被长期占用,而不被释放)
四、闭包的应用场景
结论:闭包找到的是同一地址中父级函数中对应变量最终的值

例子1:

function funA(){
  var a = 10;  // funA的活动对象之中;
  return function(){   //匿名函数的活动对象;
        alert(a);
  }
}
var b = funA();
b();  //10

例子2:

function outerFn(){
  var i = 0; 
  function innerFn(){ //闭包函数
      i++;
      console.log(i);
  }
  return innerFn;
}
var inner = outerFn();  //每次外部函数执行的时候,都会开辟一块内存空间,外部函数的地址不同,都会重新创建一个新的地址
inner(); //1
inner(); //2
inner(); //3
var inner2 = outerFn();	//闭包函数的外部函数有初值i=0,两个函数使用各自的变量
inner2(); //1
inner2(); //2
inner2(); //3

例子3:

//情况1
//闭包函数的外部函数没有初值
var i = 0;  //全局变量

function outerFn(){
  function innnerFn(){
       i++;
       console.log(i);
  }
  return innnerFn;
}

var inner1 = outerFn(); //闭包函数的外部函数也没有初值,用的全局变量
var inner2 = outerFn(); 
//两个函数共用同一个全局变量
inner1();	//1
inner2();	//2
inner1();	//3
inner2();	//4

//情况2
//闭包函数的外部函数有初值
function outerFn(){
var i = 0;
  function innnerFn(){
      i++;
      console.log(i);
  }
  return innnerFn;
}
var inner1 = outerFn();
var inner2 = outerFn();
inner1();	//1
inner2();	//1
inner1();	//2
inner2();	//2

场景例子4:打车价格计算

  1. 起步价 13(3公里内),之后每多一公里增加 5 块钱,用户输入公里数就可以计算打车价格。
  2. 如果拥堵,多收十元.

  • 用 ES6 的语法在对象中定义函数的时候,可以删除 function 关键词和冒号
五、闭包总结
  1. 闭包是什么:闭包是一个函数(一个作用域可以访问另外一个函数的局部变量)。
  2. 闭包的作用是什么:延伸变量的作用范围。

没有产生闭包,因为并没有局部变量,所以访问到的是全局变量 The Window

let name = 'The Window'
let object = {
    name: 'My Object',
    getNameFunc(){
        return function(){
            return this.name
        }
    }
}
let f = object.getNameFunc()
console.log(f()) //The Window

产生了闭包:因为 this 在函数内部被赋值给了 that,指向的是 object 这个对象。

let name = 'The Window'
let object = {
    name: 'My Object',
    getNameFunc(){
        let that = this
        return function(){
           return that.name
        }
    }
}
let f = object.getNameFunc()
console.log(f()) //My Object
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值