инкапсуляция в шаблон модуля javascript

Я читал эту ссылкуhttp://addyosmani.com/largescalejavascript/#modpattern

И увидел следующий пример.

var basketModule = (function() {
var basket = []; //private

return { //exposed to public
       addItem: function(values) {
            basket.push(values);
        },
        getItemCount: function() {
            return basket.length;
        },
        getTotal: function(){
            var q = this.getItemCount(),p=0;
            while(q--){
                p+= basket[q].price;
            }
        return p;
        }
      }
}());

basketModule.addItem({item:'bread',price:0.5});
basketModule.addItem({item:'butter',price:0.3});

console.log(basketModule.getItemCount());
console.log(basketModule.getTotal());

Согласно статистике, «шаблон модуля является популярным дизайном, который инкапсулирует «конфиденциальность», состояние и организацию с помощью замыканий». Чем это отличается от написания, как показано ниже? Разве конфиденциальность не может быть просто обеспечена с помощью области действия?

var basketModule = function() {
var basket = []; //private
       this.addItem = function(values) {
            basket.push(values);
        }
        this.getItemCount = function() {
            return basket.length;
        }
        this.getTotal = function(){
            var q = this.getItemCount(),p=0;
            while(q--){
                p+= basket[q].price;
            }
        return p;
        }

}

var basket = new basketModule();

basket.addItem({item:'bread',price:0.5});
basket.addItem({item:'butter',price:0.3});

5
задан eirikrl 28 April 2012 в 11:11
поделиться