JavaScript 进阶第八章(闭包)

Posted 海海呐

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript 进阶第八章(闭包)相关的知识,希望对你有一定的参考价值。

概念

计算机科学中,闭包(英语:Closure),又称词法闭包(Lexical Closure)或函数闭包(function closures),只要出现引用了外部变量的函数,那么这个现象就叫做闭包

作用

  1. 让数据变得更加的安全

  2. 优化代码

  3. 函数内返回了另外一个函数

代码演示 

不使用闭包

<body>
  <button>自增</button>
  <h1></h1>
 <script>
    const btn = document.querySelector("button");
    const h1 = document.querySelector("h1");
    let num = 0;
    let arr = [{ name: "上路" }, { name: "中路" }, { name: "射手" }, { name: "打野" }, { name: "辅助" }];

    h1.innerText = arr[num].name;
    btn.onclick = function () {
      num++;
      if (num >= arr.length) {
        num = 0;
      }
      h1.innerText = arr[num].name;
    }
  </script>
</body>

使用闭包

<body>
  <button>自增</button>
  <h1></h1>
  <script>

    const btn = document.querySelector("button");
    const h1 = document.querySelector("h1");

    function setElements() {
      let num = -1;
      let arr = [{ name: "上路" }, { name: "中路" }, { name: "射手" }, { name: "打野" }, { name: "辅助" }];
      return function () {
        num++;
        if (num >= arr.length) {
          num = 0;
        }
        return arr[num].name;
      }
    }

    const getElement=setElements();

    h1.innerText = getElement();
    btn.onclick = function () {
      h1.innerText = getElement();
    }
  </script>
</body>

上一章:JavaScript 进阶第七章(es6中的class)

下一章:JavaScript 进阶第九章(原型链继承)

以上是关于JavaScript 进阶第八章(闭包)的主要内容,如果未能解决你的问题,请参考以下文章

第八章网络编程进阶

数据库系统概念笔记——第八章:关系数据库设计

第八章

JavaScript语言精粹_第八章

JavaScript DOM编程艺术-学习笔记(第八章第九章)

odoo官方文档第八章 Testing in odoo (odoo的测试)