回到课程

Counter 对象

重要程度: 5

这里通过构造器函数创建了一个 counter 对象。

行得通?它会显示什么呢?

function Counter() {
  let count = 0;

  this.up = function() {
    return ++count;
  };
  this.down = function() {
    return --count;
  };
}

let counter = new Counter();

alert( counter.up() ); // ?
alert( counter.up() ); // ?
alert( counter.down() ); // ?

当然行得通。

嵌套函数都是在同一个词法环境中创建的,所以它们可以共享对同一个 count 变量的访问:

function Counter() {
  let count = 0;

  this.up = function() {
    return ++count;
  };

  this.down = function() {
    return --count;
  };
}

let counter = new Counter();

alert( counter.up() ); // 1
alert( counter.up() ); // 2
alert( counter.down() ); // 1