0

我有一个 TabContainer 类。此类是 Ext.tab.Panel 的扩展。创建工作正常,但是,当我尝试向实例发送消息时 Firebug 说:

“TypeError:tbbar.canAddTab 不是函数”

课程是:

Ext.define('KMA.view.environment.TabContainer',{
    extend: 'Ext.tab.Panel',
    alias: 'widget.environmenttabcontainer',

    initComponent: function(){
        [...]
        this.callParent(arguments);
    },
    createTab: function(aTitle,aToolTip,anItem){
        return {
            title: aTitle,
            itemId: aTitle + "Tag",
            tabconfig: {
                title: aTitle,
                tooltip: aToolTip,
                items: anItem
            }    
        };
    },
    openTabs: function(){
        return this.getItems().length;
    },
    maxOpenTabs: function(){
        return 7;
    },
    canAddTab: function(){
        return (this.openTabs() < this.maxOpenTabs());
    },
    addTab: function(aTabCfg){
        this.add(aTabCfg);
    }
});

我的示例代码是:

var tbbar = Ext.ComponentQuery.query('environmenttabcontainer');
console.log(tbbar);
console.log(tbbar.canAddTab());

在第一个“console.log”中,Firebugs 显示了 TabContainer 的实例,并显示了该类的方法。但是,为什么不工作?任何想法 ?

4

1 回答 1

2

我猜它不起作用,因为Ext.ComponentQuery.query返回一个数组。这有效:

var t = new KMA.view.environment.TabContainer();
Ext.ComponentQuery.query('environmenttabcontainer')[0].canAddTab
 > function (){
         return (this.openTabs() < this.maxOpenTabs());
    }

您是否有理由使用组件查询而不是直接引用?

于 2013-03-28T23:39:02.777 回答