闭包

作用域链

  • 函数在执行的过程中,先从自己内部找变量
  • 如果找不到,再从创建当前函数所在的作用域(词法作用域)去找,以此往上
  • 注意找的是变量的当前的状态
    函数联通它的作用域链上的找的这个变量,共同构成闭包
    一般情况下使用闭包主要是为了
  1. 封装数据
  2. 暂存数据

典型闭包

function car(){
  var speed = 0
  function fn(){
    speed++
    console.log(speed)
  }
  return fn
}

var speedUp = car()
speedUp()   //1
speedUp()   //2

如下代码输入出多少?如果输出3,那如何改造代码?

var fnArr = [];
for (var i = 0; i < 10; i ++) {
  fnArr[i] =  function(){
    return i
  };
}
console.log( fnArr[3]() )
var fnArr = [];
for (var i = 0; i < 10; i++) {
    (function (i) {
        fnArr[i]= function () {
            return i
        }
    })(i);
}
console.log( fnArr[3]() )//3

封装一个car对象

var Car = (function(){
   var speed = 0;
   //补充
   return {
      setSpeed: setSpeed,
      get: get,
      speedUp: speedUp,
      speedDown: speedDown
   }
})()
Car.set(30)
Car.get() //30
Car.speedUp()
Car.get() //31
Car.speedDown()
Car.get()  //30
var Car = (function(){
    var speed = 0;
    function set(speed1){
        speed = speed1
        console.log(speed)
    }
    function get(){
        console.log(speed)
        return speed;
    }
    function speedUp(){
        speed++;
        console.log(speed)
    }
    function speedDown(){
        speed--;
        console.log(speed)
    }
    return {
        set: set,
        get: get,
        speedUp: speedUp,
        speedDown: speedDown
    }
})()
Car.set(30)
Car.get() //30
Car.speedUp()
Car.get() //31
Car.speedDown()
Car.get()  //30

如下代码输出多少?如何连续输出 0,1,2,3,4?

for(var i=0; i<5; i++){
  setTimeout(function(){
    console.log('delayer:' + i )
  }, 0)
}
    (function (j) {
        setTimeout(() => {
            console.log( + j ) 
        }, 0);
    })(i)  
}
//0,1,2,3,4

如下代码输出多少?

function makeCounter() {
  var count = 0

  return function() {
    return count++
  };
}

var counter = makeCounter()
var counter2 = makeCounter();

console.log( counter() ) // 0
console.log( counter() ) // 1

console.log( counter2() ) // ?
console.log( counter2() ) // ?

function makeCounter() {
    var count = 0
  
    return function() {
      return count++
    };
  }
  
  var counter = makeCounter()
  var counter2 = makeCounter();
  
  console.log( counter() ) // 0
  console.log( counter() ) // 1
  
  console.log( counter2() ) // 0
  console.log( counter2() ) // 1

补全代码,实现数组按姓名、年纪、任意字段排序。

var users = [
  { name: "John", age: 20, company: "Baidu" },
  { name: "Pete", age: 18, company: "Alibaba" },
  { name: "Ann", age: 19, company: "Tecent" }
]

users.sort(byField('age'))
users.sort(byField('company'))
var users = [
    { name: "John", age: 20, company: "Baidu" },
    { name: "Pete", age: 18, company: "Alibaba" },
    { name: "Ann", age: 19, company: "Tecent" }
]
function byField(string){
    return function(user1,user2){
        return user1[string] >user2[string]
    }
}
users.sort(byField('age'));
users.sort(byField('name'))
users.sort(byField('company'))

写一个 sum 函数,实现如下调用方式。

console.log( sum(1)(2) ) // 3
console.log( sum(5)(-1) ) // 4
function sum(a) {
    return function (b) {
        return a + b;
    }
}
console.log( sum(1)(2) ) // 3
console.log( sum(5)(-1) ) // 4

待补充

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 一、作用域 A、定义 代码在运行时,各个变量、函数和对象的可访问性。换句话说,作用域决定了你的代码里的变量和其他资...
    5吖阅读 659评论 0 1
  • 变量 变量分为全局变量和局部变量,全局变量就是指该变量的作用域为当前文档,也就是说全局变量在当前文档的所有Java...
    jrg陈咪咪sunny阅读 377评论 0 1
  • 闭包是自包含的功能块,可以在代码中传递和使用。Swift中的闭包类似于C和Objective-C中的block,也...
    微笑中的你阅读 408评论 0 0
  • 需求是使用3个check选中日 显示当日贡献选中周 显示本周累计贡献选中总 显示历史总数累计贡献3个都不选中 则显...
    人气小哥阅读 656评论 0 0
  • 6公司今年不放假,今年春节又要在劳动中度过了。腊月二十五昌乐大集,与阿华去农贸城采购年货。买了一只公鸡,一只母鸡(...
    南良大维阅读 246评论 0 3