Ext JS 4:使用私有变量数组错误创建类



假设我有以下代码(在此jsfiddle上可用):

Ext.onReady(function() {
  Ext.define('TestBlah', {
    extend: 'Ext.panel.Panel',
    counter: 0,
    counters: [],
    initComponent: function() {
      alert("counter: " + this.counter);    // should show 0
      alert("counters: " + this.counters);    // should show nothing
      this.counter++;
      this.counters.push(1);
      this.callParent();
    }
  });
  var one = Ext.create('TestBlah');
  //one.destroy();
  var two = Ext.create('TestBlah');
});

所以我所做的只是创建一个包含 2 个私有变量的简单类:counter(整数)和counters(数组)。 现在,当我创建类时,我希望onetwo都不会从另一个继承。 这仅适用于counter. 当我创建two时,计数器为 0,计数器数组为 1。 即使我在创建two之前添加了one.destroy();,它仍然具有计数器的值。 这是一个错误吗?

这不是

一个错误。当您声明一个类时,所有内容都会推送到类原型,这意味着它们在所有实例之间共享。对于"基元"类型值,它没有任何区别,但对于数组/对象,这些值将在类的所有实例之间共享。要修改此行为,请在initComponent内设置计数器:

this.counters = [];

最新更新