搜索

首页  >  问答  >  正文

关于匿名自执行函数的问题

以下两种代码有什么区别?有何有缺点?谢谢

//第一种var counter = (function(){    var i = 0;    return {
        get: function(){            return i;
        },
        set: function(val){
            i = val;
        },
        increment: function(){            return ++i;
        }
    }
}());
//第二种var counter = {    var i = 0;
    get: function(){            return i;
    },
    set: function(val){
            i = val;
    },
    increment: function(){            return ++i;
    }
}


一辆想出轨的无轨电车一辆想出轨的无轨电车2897 天前1099

全部回复(2)我来回复

  • 数据分析师

    数据分析师2017-10-01 00:17:01

    关于匿名自执行函数的问题-PHP中文网问答-关于匿名自执行函数的问题-PHP中文网问答

    围观一下哦,学习一下。

    回复
    0
  • 巴扎黑

    巴扎黑2017-02-14 11:07:11

    第二种是对象字面量的书写方式,但你的写法是错误的,正确写法应该是:

    var counter = {
        i: 0,
        get: function(){            return this.i;
        },
        set: function(val){            this.i = val;
        },
        increment: function(){            return ++this.i;
        }
    }

    这种写法不会隔离作用域,也就是说外部可以直接访问内部的属性,并可以修改他,如:count.i。
    而第一种写法实际上是一种闭包,他可以避免这个问题,即外部环境只能通过你暴露的接口访问内部属性,很好的隔离了作用域。但缺点是可能会造成内存泄漏,用大量闭包也会占用大量内存。

    回复
    0
  • 取消回复