再谈JavaScript中的闭包

Posted 路虽远,行则必至

tags:

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

一、什么是闭包

闭包就是有权访问另一个函数作用域中变量的函数,因此,闭包的本质是一个函数。当一个内部函数被保存到外部时,就会生成闭包。

二、闭包的作用

 1、实现公有变量,即通过局部变量实现全局变量的效果

案例:定义一个函数,每调用 一次数字累加一次,即计数器效果

//非闭包实现
var num = 0;
function count() {
    console.log(++num);
}
count(); // 1
count(); // 2
count(); // 3
//闭包实现
function count() {
    var num = 0;
    function add() {
        console.log(++num);
    }
    return add;
}
var myCount = count();
myCount(); // 1 
myCount(); // 2
myCount(); // 3

 2、实现缓存,即多个函数可同时操作一个局部变量

function demo() {
    var fruit = ‘apple‘;
    var obj = {
        eatFruit: function() {
            if (fruit != ‘‘) {
                console.log(‘eat => ‘ + fruit);
                fruit = ‘‘;
            } else {
                console.log(‘empty‘);
            }
        },
        pushFruit: function(myFruit) {
            fruit = myFruit;
        }
    }
    return obj;
}
var boy = demo();
boy.eatFruit(); // eat => apple
boy.eatFruit(); // empty
boy.pushFruit(‘grape‘);
boy.eatFruit(); // eat => grape

 3、实现封装属性私有化

也就是对象无法直接访问函数内部定义的同级变量,只能通过对象相应的方法来操作变量,仍以上一代码为例

function demo() {
    var fruit = ‘apple‘;
    var obj = {
        eatFruit: function() {
            if (fruit != ‘‘) {
                console.log(‘eat => ‘ + fruit);
                fruit = ‘‘;
            } else {
                console.log(‘empty‘);
            }
        },
        pushFruit: function(myFruit) {
            fruit = myFruit;
        }
    }
    return obj;
}
var boy = demo();
console.log(boy.fruit); // undefined 

无法通过 对象点变量名 的方式直接访问变量,只能通过对象内部封装的方法来操作变量

4、模块化开发,防止污染全局变量

var demo = ‘全局内demo‘;

var init = (function(){
    var demo = ‘init局部内demo‘;
    function show() {
        console.log(demo);
    }
    return function() {
        show();
    }
}());

init(); // init局部内demo

var test = (function(){
    var demo = ‘test局部内demo‘;
    function show() {
        console.log(demo);
    }
    return function() {
        show();
    }
}())

test(); // test局部内demo

init和test为独立模块,执行 init 和 test 函数后只会输出内部同名变量,不会影响全局同名变量。

三、闭包的害处

闭包会导致原有作用域链不释放,造成内存泄露,过多闭包会严重影响运行速度

 

以上是关于再谈JavaScript中的闭包的主要内容,如果未能解决你的问题,请参考以下文章

再谈JavaScript的closure--JavaScript 闭包

再谈闭包

再谈闭包

JS---闭包

Javascript中的闭包

javascript中的闭包