嵌套类的范围问题

时间:2014-10-25 22:15:12

标签: javascript oop timer scope mootools

我无法访问嵌套类的方法。这是我到目前为止所尝试的。主要问题是调用TimerTask.execute()。该错误表明任务未定义。

  

未捕获的TypeError:undefined不是函数

程序应在计时器上显示十次运行的增量编号。



var TimerTask = new Class({
  initalize: function (options) {
    this.counter = options.counter;
    this.run = options.run;
    this.onComplete = options.complete;
    this.done = false;
  },
  execute : function() {
    var me = this;
    this.counter--;
    if (this.done === false || this.counter <= 0) {
      this.done = true;
      me.onComplete.call(me);
    } else {
      me.run.call(me);
    }   
  }
});

var Timer = new Class({
  initialize: function (options) {
    this.id = 0;
    this.running = true;
    this.count = 0;
    this.delay = options.delay || 1000;
    this.tasks = options.tasks || [];
  },
  start: function () {
    var me = this;
    me.id = setInterval(function tick() {
      if (!me.running) return;
      for (var i = 0; i < me.tasks.length; i++) {
        me.tasks[i].execute();
      }
      me.count++;
    }, this.delay);
  },
  pause: function pause() {
    this.running = false;
    return this;
  },
  run: function run() {
    this.running = true;
    return this;
  },
  stop: function stop() {
    clearInterval(this.id);
    this.stopped = true;
    return this;
  },
  schedule: function (task) {
    this.tasks.push(task);
  }
});

var i = 0;
var t1 = new Timer({
  delay: 1000,
  tasks: [
    new TimerTask({
      run: function () {
        document.getElementById('output').innerHTML = parseInt(i++, 10);
      },
      onComplete: function () {
        alert('DONE!');
      },
      counter: 10
    })]
});

t1.start();
&#13;
<script src="//cdnjs.cloudflare.com/ajax/libs/mootools/1.5.0/mootools-core-full-compat.min.js"></script>
<div id="output"></div>
&#13;
&#13;
&#13;

1 个答案:

答案 0 :(得分:1)

哦,哇。不敢相信没有人抓住TimerTask中的拼写错误。难怪我不断获得原型而不是实例。我拼写了#34;初始化&#34;没有第三个&#34;我&#34; ...

无论如何,我修复了这个问题并且代码是光荣的。

注意: 我使用此作为我的计时器的基础 - https://gist.github.com/NV/363465

&#13;
&#13;
var TimerTask = new Class({
    initialize: function (options) {
        this.counter = options.counter || 0;
        this.run = options.run;
        this.onComplete = options.onComplete;
        this.active = true;
        this.isInfinite = this.counter === 0;
    },
    execute: function () {
        if (!this.isInfinite && this.counter === 0) {
            this.active = false;
            if (this.onComplete !== undefined) {
                this.onComplete();
            }            
        } else {
            this.run();
            if (!this.isInfinite) {
                this.counter--;
            }
        }
    },
    isActive: function () {
        return this.active;
    }
});

var Timer = new Class({
    initialize: function (options) {
        this.id = 0;
        this.running = true;
        this.count = 0;
        this.delay = options.delay || 1000;
        this.tasks = options.tasks || [];
        Timer.all.push(this);
    },
    start: function () {
        var me = this;
        me.id = setInterval(function tick() {
            if (!me.running) return;
            for (var i = 0; i < me.tasks.length; i++) {
                var task = me.tasks[i];
                if (task.isActive()) {
                    task.execute();
                } else {
                    console.log('Task is complete...');
                }
            }
            me.count++;
        }, this.delay);
    },
    pause: function pause() {
        this.running = false;
        return this;
    },
    run: function run() {
        this.running = true;
        return this;
    },
    stop: function stop() {
        clearInterval(this.id);
        this.stopped = true;
        return this;
    },
    schedule: function (task) {
        this.tasks.push(task);
    }
});

Timer.extend({
    all : [],
    pause : function pause() {
        var all = Timer.all;
        for (var i = 0; i < all.length; i++) {
            all[i].pause();
        }
        return all;
    },
    run : function run() {
        var all = Timer.all;
        for (var i = 0; i < all.length; i++) {
            all[i].run();
        }
        return all;
    },
    stop : function stop() {
        var all = Timer.all;
        for (var i = 0; i < all.length; i++) {
            all[i].stop();
        }
        return all;
    }
});

function print(id, value) {
    document.getElementById(id).innerHTML = value;
}

var i = 0;
var t1 = new Timer({
    delay: 100,
    tasks: [
    new TimerTask({
        run: function () {
            print('output1', String.fromCharCode(65 + i));
        },
        onComplete: function () {
            console.log('Task 1 complete...');
        },
        counter: 26
    }),
    new TimerTask({
        run: function () {
            print('output2', parseInt(i++, 10));
        }
    })]
});

t1.start();

// After 4 seconds, stop all timers.
setTimeout(function() {
    Timer.stop();
}, 4000);
&#13;
<script src="//cdnjs.cloudflare.com/ajax/libs/mootools/1.5.0/mootools-core-full-compat.min.js"></script>
<div id="output1"></div>
<div id="output2"></div>
&#13;
&#13;
&#13;