js css htmlES6 新特性

ES6 闭包

2022-05-10  本文已影响0人  生命里那束光

闭包

一、变量作用域

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

  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
上一篇下一篇

猜你喜欢

热点阅读