码迷,mamicode.com
首页 > Web开发 > 详细

JS高级---闭包

时间:2020-01-09 19:07:00      阅读:84      评论:0      收藏:0      [点我收藏+]

标签:一个   function   延长   函数调用   数据   style   result   访问   声明   

闭包

 

闭包的概念: 函数A中, 有一个函数B, 函数B中可以访问函数A中定义的变量或者是数据, 此时形成了闭包(这句话暂时不严谨)
  • 闭包的模式: 函数模式的闭包, 对象模式的闭包
  • 闭包的作用: 缓存数据, 延长作用域链
  • 闭包的优点和缺点: 缓存数据
  • 闭包的应用

 


函数模式的闭包: 在一个函数中有一个函数

    //函数模式的闭包:在一个函数中有一个函数
    function f1() {
      var num = 10;
      //函数的声明
      function f2() {
        console.log(num);
      }
      //函数调用
      f2();
    }
    f1();


    function f1() {
      var num = 10;
      return function () {
        console.log(num); //10
        return num;
      }
    }

    var ff = f1();
    var result = ff();
    console.log(result); //10

 

 

 对象模式的闭包:函数中有一个对象

    function f3() {
      var num = 10;
      var obj = {
        age: num
      };
      console.log(obj.age);//10
    }
    f3();

 

    function f2() {
      var num = 100;
      return {
        age: num
      }
    }

    var obj = f2();
    console.log(obj.age);

JS高级---闭包

标签:一个   function   延长   函数调用   数据   style   result   访问   声明   

原文地址:https://www.cnblogs.com/jane-panyiyun/p/12172828.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!