0

在我看来,我有一个树面板及其相应的控制器。发生的事情是有两个控制器,一个用于 itemdblclick,另一个用于 itemmove。itemdblclick 工作正常,但是当我为 itemmove 添加控制器时,itemmove 工作正常,但另一方面, itemdbclick 不工作。如果我删除 itemmove 控制器,itemdblclick 正在工作。希望不要混淆:) 简单来说,这两个控制器是分开工作的,但不是一起工作的。

  1. 谁能告诉我我在这里做错了什么。

  2. 此外,在控制器的函数 editRegion 中,我尝试使用 getStore.load() 方法重新加载树,但树没有加载,即使我能够看到在 firebug 中调用的商店

编辑:

在双击树节点时打开一个表单,在关闭表单时,我希望重新加载树面板。这就是我想在editregion函数中发生的事情

看法

{
            xtype : 'treepanel',
            title : '',
            id : 'hierarchyTree',
            border : false,
            alias : 'widget.hierarchyTree',
            height : 1000,
            viewConfig : {
                enableDD : true,
                plugins : {
                    ptype : 'treeviewdragdrop'
                }
            },
            collapsible : false,
            useArrows : true,
            rootVisible : false,
            store : Ext.create('App.store.HierarchyTree'),
            displayField : 'Title',
            multiSelect : false,
            singleExpand : false,


        }

控制器

refs : [{
    ref : 'myHierarchyTree',
    selector : '#hierarchyTree'
}
    init : function() {

    this.getHierarchyTreeStore().load();

'#hierarchyTree' : {
            itemdblclick : this.itemdblclick

        },
        '#hierarchyTree' : {
            itemmove : this.itemmove

        }

itemdblclick : function(view, record, level) {


    if (record.get('LevelID') == 1) {

        this.erWin = Ext.create('App.view.EditRegions');
        var f = this.getEditregionform().getForm();
        f.loadRecord(record);
        this.erWin.showWin();
    } 
else if (record.get('LevelID') == 2) {

        this.eaWin = Ext.create('App.view.EditAreas');
        var f = this.getEditareaform().getForm();
        f.loadRecord(record);
        this.eaWin.showWin();
    }

itemmove : function(v, oldParent, newParent, index, eOpts) {
    var nodeID = v.data.id;
    var oldParent = oldParent.data.id;
    var newParent = newParent.data.id;
    var index = index;
    var level = v.data.LevelID;

Ext.Ajax.request({
        url : 'data/Locations.aspx',
        params : {

            mode : 'MOVENODE',
            currentNode : nodeID,
            oldParentNode : oldParent,
            newParentNode : newParent

        },
        success : function() {
            alert(LANG.SUC);
            Ext.getStore('HierarchyTree').load();

        },
        failure : function() {

        }
    });


editRegion : function(button, record) {

    var fp = button.up('form');

    if (fp.getForm().isValid()) {
        fp.getForm().submit({
            url : 'data/Locations.aspx',
            params : {
                mode : 'EDITREGION',
                userID : ME.UserID,
                RegionID : ME.RegionID
            },
            success : function(response) {
                alert(LANG.SUC);
                this.getHierarchyTreeStore().load();


            },
            failure : function(response) {
                alert('Try again');
            }
        });
    }
}
4

2 回答 2

1

分别添加它们将导致第一个侦听器对象被覆盖。

使固定:

       '#hierarchyTree' : {
            itemdblclick : this.itemdblclick,
            itemmove : this.itemmove
        },

您应该检查商店是否相同。意思是检查 id 因为我认为控制器初始化一个商店和另一个面板。所以检查是否this.getHierarchyTreeStore().id与树面板中的相等。您可以从类似的按钮导航到它button.up().down('treepanel').getStore().id。如果它们不同,那么您应该使用第二种方法来获取商店。

于 2012-09-07T15:14:57.567 回答
0

尝试执行以下代码,因为使用 up 和 down 不会引用正确的视图,因为树和表单是完全不同的视图

    var view = Ext.widget('hierarchy');
view.down('treepanel').getStore.load();

现在,即使商店正在重新加载,也会出现错误

TypeError: view.down("treepanel") is null

view.down('treepanel').getStore.load();
于 2012-09-07T16:02:38.933 回答