美文网首页
JavaScript闭包

JavaScript闭包

作者: 遇明不散 | 来源:发表于2019-08-11 12:47 被阅读0次

闭包

什么是闭包

闭包是一种特殊的函数

如何产生闭包

当一个内部函数引用了外部函数的数据(函数/变量)时,那么内部的函数就是闭包

闭包特点

只要闭包还在使用外部函数的数据,那么外部函数就一直不会被释放,也就是可以延长外部函数的声明周期

闭包注意点
  • 当后续不需要使用闭包时,一定要手动将闭包设置为null,否则会出现内存泄露
  • 默认情况下通过var定义的变量, 只要不是定义在函数中都是全局变量
  • 在ES6中如果在循环中通过let定义的变量, 那么这个变量是一个局部变量
  • 在ES6中由于{}是块级作用域, 所以只要在块级作用域中定义了一个函数并且这个函数中用到了块级作用域中的数据, 那么这个函数就是闭包
  • for循环中通过let定义的变量每次执行循环体都会重新定义一个新的,也就是每个循环体都有一个属于自己的变量
  • for循环中如果定义了函数, 这个函数用到了通过let定义的变量, 那么这个函数是一个闭包
function test() {
  var test = 666;
  return function demo() {
      console.log(test);
   }
}

let fn = test();
fn();  // 666

for(let i = 0; i < 3; i++){ // 0 1 2 3
// 由于i是局部变量, 所以每次执行完循环体都会重新定义一个i变量
// test 为闭包函数
        function test() {
            console.log(i); // 3
        }
    }
    test(); // 2
闭包循环索引
/*
<button>按钮1</button>
<button>按钮2</button>
<button>按钮3</button>
*/
// 通过let依次设置
let oBtns = document.querySelectorAll('button');
for (var i = 0; i <= oBtns.length - 1; i++){
      let item = oBtns[i];
      item.onclick = function () {
         console.log(i);
    }
}

// 通过var
let oBtns = document.querySelectorAll('button');
for (var i = 0; i <= oBtns.length - 1; i++){
        let item = oBtns[i];
        (function test(index) {
            item.onclick = function () {
                console.log(index);
            }
        })(i);
}

排它思想

清除其它非选中元素的样式,只设置选中元素的样式

/*
<ul>
    <li class="cur">1</li>
    <li>2</li>
    <li>3</li>
    <li>4</li>
    <li>5</li>
</ul>
*/

// let
 let oLis = document.querySelectorAll('li');
    let preIndex = 0;
    for (let i = 0; i < oLis.length; i++){
        let item = oLis[i];
        item.onclick = function () {
            let preItem = oLis[preIndex];
                preItem.className = '';

                this.className = 'cur';
                preIndex = index;
        };
    }

// var
 for (var i = 0; i < oLis.length; i++){
        var item = oLis[i];
        (function (index) {
            item.onclick = function () {
                let preItem = oLis[preIndex];
                preItem.className = '';

                this.className = 'cur';
                preIndex = index;
            }
        })(i);
    }

相关文章

  • JavaScript----闭包

    javascript之闭包 闭包的概念     闭包(closure)是 JavaScript 的一种语法特性。 ...

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

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

  • javascript中闭包是什么

    javascript中闭包是什么 JavaScript 变量可以是局部变量或全局变量。私有变量可以用到闭包。闭包就...

  • Javascript 闭包

    闭包 (注:所以案例以 javascript 实现) 初识闭包 什么是闭包 MDNClosures are fun...

  • 作用域闭包

    概览 背景知识:JavaScript内存管理、JavaScript作用域。 内容 1 闭包定义 闭包:当函数可以记...

  • JavaScript 作用域

    概览 背景知识:JavaScript内存管理、JavaScript作用域。 内容 1 闭包定义 闭包:当函数可以记...

  • 20170815 前端开发日报

    JavaScript闭包,只学这篇就够了 闭包不是魔法 这篇文章使用一些简单的代码例子来解释JavaScript闭...

  • JavaScript深入理解-闭包(Closure)

    推荐文章:学习Javascript闭包(Closure)- 阮一峰javascript深入理解-从作用域链理解闭包...

  • 闭包

    学习Javascript闭包(Closure)

  • JS之闭包与IIFE

    本篇文章主要讨论了: JavaScript引擎 全局对象 闭包 循环 + 闭包 IIFE + 闭包 1.JavaS...

网友评论

      本文标题:JavaScript闭包

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