js闭包

作者: 神奇的少年 | 来源:发表于2025-02-16 15:01 被阅读0次

1、原理
允许函数保存其被声明时作用域中的变量;即使函数在作用域外被调用。

2、示例

function outer() {
    let value = 1;
    return function inner() {
        value ++;
        console.log(value);
    }
};

const test1 = outer();
const test2 = outer();
test1();// 输出2
test1();// 输出3
test2();// 输出2

第二次调用test1函数的时候,函数内作用域中的value因上面被调用过一次,故保存了结果2的变量;

3、应用场景

3.1、保存事件处理中所需的数据;

<body>
    <button id="btn1">按钮1</button>
    <button id="btn2">按钮2</button>
</body>
function createClickHandler(message) {
  return function() {
      alert(message);
   };
}
const btn1 = document.getElementById('btn1');
const btn2 = document.getElementById('btn2');
btn1.addEventListener('click', createClickHandler('你点击了按钮1'));
btn2.addEventListener('click', createClickHandler('你点击了按钮2'));

3.2、循环中的事件绑定

<ul>
    <li>按钮1</li>
    <li>按钮2</li>
    <li>按钮3</li>
</ul>
const ListItems = document.querySelectorAll('li');
for (let i = 0; i < ListItems.length; i++) {
  ListItems[i].addEventListener('click', (function (index) {
      return function () {
        alert('你点击了第${index + 1}项');
      }
  })(i));
}

相关文章

  • php之闭包函数(Closure)

    php闭包函数(Closure) JS闭包 js和php闭包使用和区别

  • JS闭包

    JS闭包 闭包练习

  • JS闭包问题(二)

    在之前的JS闭包问题(一)文章中大概介绍了一下JS闭包,同时讲了闭包与变量之间的问题,今天我们继续聊闭包,聊聊闭包...

  • JS闭包大结局(JS闭包系列3)

    在上一篇中再谈JS闭包(JS闭包系列2),我详细的介绍了JS中的变量作用域相关的概念,结合第一节关于JS闭包(JS...

  • JS闭包入门

    最近有看到朋友的面经里提到的JS闭包的问题,就想研究研究,以下是我对JS闭包的简单理解。 到底什么是JS闭包? 定...

  • 学习JavaScript闭包和作用域笔记

    JS JavaScript闭包和作用域 闭包 JavaScript高级程序设计中对闭包的定义:闭包是指有权访问另外...

  • 再谈JS闭包(JS闭包系列2)

    这篇文章,来继续谈谈Javascript闭包的剩余问题。因为在上一篇文章中关于JS闭包(JS闭包系列1)主要简单的...

  • 简单的聊一下闭包

    js中的闭包 闭包是学习js中永远也绕不过去的一个坎,那么,今天我们就去一段简单的代码开始聊一聊闭包 什么是闭包 ...

  • 浅谈闭包

    js中的闭包 闭包是学习js中永远也绕不过去的一个坎,那么,今天我们就去一段简单的代码开始聊一聊闭包 什么是闭包 ...

  • 闭包??

    什么闭包,闭包有什么用?http://js.jirengu.com/pogadikofa/1/闭包是在某个作用域内...

网友评论

      本文标题:js闭包

      本文链接:https://www.haomeiwen.com/subject/rnbdpjtx.html