2011-04-19 59 views
1

我想插入一個新的節點到我的樹中。 我發展與煎茶庫版本4. 樹節點似乎不工作... Firebug的錯誤:如何在ExtJS4的TreePanel中插入新節點?

ERREUR:未捕獲的異常:Ext.Loader未啓用,因此依賴不能動態地解決。缺少所需的類:Ext.tree.TreeNode

我已添加Loader config enable:true。它不工作太... ...!

我的代碼:

/*Ext.Loader.setConfig({ 
      enabled: true 
}); 
*/ 
Ext.require([ 

    'Ext.form.*', 
    'Ext.grid.*', 
    'Ext.tree.*', 
    'Ext.data.*', 
    'Ext.util.*', 
    'Ext.loader.*', 
    'Ext.state.*', 
    'Ext.layout.container.Column', 
    'Ext.tab.TabPanel' 

]); 


Ext.onReady(function(){ 

    Ext.QuickTips.init(); 

     Ext.define('Task', { 
      extend : 'Ext.data.Model', 
      fields : [ 
       { name : 'id', type :'int'}, 
       { name : 'task', type : 'string' }, 
       { name : 'material', type : 'string'}, 
       {name : 'cc' , type : 'string'}, 
       { name : 'date_debut', type : 'string'} 
      ] 
     }); 

     var store = Ext.create('Ext.data.TreeStore',{ 

       model : 'Task', 
       proxy : { 
        type : 'ajax', 
        url : 'myjson.json' 

       }, 
       folderSort: true 
     }); 

     var tree = Ext.create('Ext.tree.TreePanel',{ 

      title : 'Task Manager', 
      width :1000, 
      height : 400, 
      //renderTo : Ext.getBody(), 
      collapsible : true, 
      useArrows : true, 
      rootVisible : false, 
      store : store, 
      multiSelect : true, 
      itemId : 'id', 
      singleExpand : true, 
      tbar : [ 
       { 
        xtype : 'button' , text : 'ADD TASK ', 
        handler : function(){ 

         var selectedItem = tree.getSelectionModel().getSelection(); 

          if(!selectedItem){ 

           selectedItem = tree.getRootNode(); 
          } 

          handleCreate = function(btn, text,cBoxes){ 
           if(btn=='ok' && text){ 

             //alert('oui'); 
             //var newNode = new Ext.tree.TreeNode({}); 
             var newNode = Ext.create('Ext.tree.TreeNode',{ 

               id : '0', 
               task : text, 
               material : 'New Material', 
               cc : 'new CC', 
               date_debut :'00/00/00', 

               leaf : false, 
               allowChildren : false 
             }); 
             if(selectedItem.isLeaf()) { 
              selectedItem.parentNode.insertBefore(newNode, selectedItem.nextSibling); 
             } else { 
              selectedItem.insertBefore(newNode, selectedItem.firstChild); 
             } 
           }else{ 
            alert('non'); 
           } 

          } 
         Ext.MessageBox.show({ 
          title:'Add new Folder Item', 
          msg: 'Name of Folder Item:', 
          buttons: Ext.MessageBox.OKCANCEL, 
          prompt:true, 
          fn: handleCreate 
         }); 
         } 

       } 

      ], 
      listeners : { 
       itemclick : function(a,b,c,d,e){ 
         var size = b.length; 
        // alert(d + ' ' + b.toString()+' b size = '+size+' e ' + e + ' a ' + a); 
         if(b instanceof Task){ 
           // Form = les champs dans le form editable 
           var form = fields.getForm(); 
           //Chaque field de la zone d'edition 
           var fId = form.findField('id'); 
           var ftask = form.findField('task'); 
           var fmaterial = form.findField('material'); 
           var fcc = form.findField('cc'); 
           var fStartDate = form.findField('start_date'); 

           fId.setValue(b.get('id')); 
           ftask.setValue(b.get('task')); 
           fmaterial.setValue(b.get('material')); 

         } 

       } 
      }, 
      //plugins: [cellEditing], 

      columns : [{ 
       text : 'ID', 
       dataIndex : 'id', 
       sortable : true, 
       width : 50  
      },{ 
       xtype : 'treecolumn', 
       text : 'Task', 
       flex : 2, 
       sortable : true, 
       dataIndex : 'task', 
       width : 100 
      }, 
      { 
       text : 'Material', 
       dataIndex : 'material', 
       width : 100 
      }, 
      { 
       text : 'CC', 
       dataIndex : 'cc', 
       width : 100 

      }, 
      { 
       text : 'Date_Debut', 
       dataIndex : 'date_debut', 
       width : 100 
      }]       


     }); 
     var states = Ext.create('Ext.data.Store', { 
     fields: ['abbr', 'name'], 
     data : [ 
      {"abbr":"AL", "name":"Alabama"}, 
      {"abbr":"AK", "name":"Alaska"}, 
      {"abbr":"AZ", "name":"Arizona"} 

      ] 
     }); 



     var fields = Ext.create('Ext.form.Panel',{ 

      frame : true, 
      title : 'Editing Zone', 
      width : 1000, 
      fieldDefaults : { 
       msgTarget : 'side', 
       labelWidth : 75 
      }, 
      defaultType : 'textfield', 
      defaults : { 
        anchor : '100%' 
      }, 


      items : [ 
      //TaskName 
      { 
       fieldLabel : 'TaskName', 
       name : 'task', 
       allowBlank : false 
      },{ 
       xtype: 'combo', 
       name : 'material', 
       fieldLabel: 'Choose Material', 
       store: states, 
       queryMode: 'local', 
       displayField: 'name', 
       valueField: 'abbr' 
      },{ 

       xtype:'datefield', 
       anchor : '100%', 
       disabledDays: [0, 6], 
       fieldLabel : 'date_debut' 

      },{ 
       xtype : 'hiddenfield', 
       name : 'id' 


      }], 
       layout: 'hbox', 
       buttons: [{ 
        text: 'Reset', 
        handler: function() { 
         this.up('form').getForm().reset(); 
        } 
        }, { 
         text: 'Submit', 
         formBind: true, //only enabled once the form is valid 

         handler: function() { 


          var id =this.up('form').getForm().findField('id'); 
          var id2 = id.getValue(); 
          var node = tree.getSelectionModel().getSelection(); 

          alert(node); 
         } 

      }], 

     }); 
     fields.render('mesfields'); 
     tree.render('mongrid'); 


}); 

回答

2

不知道有錯誤,因爲我沒有測試你的代碼...

但是從這個論壇上,我得到的結論是Ext.require包括來自file system腳本... 像

Ext.require([ 
    'Ext.form.*', 
    'Ext.tree.*', 
]); 

這意味着包括src/form/src/tree/所有的JS

你得到的錯誤是因爲​​
並沒有在C:\xampp\htdocs\ext-4b3\src\tree(我的地方)一個TreeNode.js。

+0

對不起,只是可以告訴你爲什麼...我仍然在學習數據模型在ext4 .. – 2011-04-19 17:08:07

8

我假設這是最初的3.x代碼,你轉換到4.0? TreeNode類不再存在於4.0中。相反,您會創建一個標準Model實例並將其附加到您的樹中。在4.0中,樹的模型(3.x中的記錄)使用新的NodeInterface類進行「裝飾」,這意味着您的模型對象在樹中使用時也將具有節點API。即,不需要與模型本身分開的TreeNode對象。

7

您好我喝了在doc類似的問題,並尋找發現:

Ext.data.NodeInterface,從TreePanel中在我的情況,我得到根節點和方法添加一個子節點apendChild

Ext.Ajax.request({ 
    loadMask: true, 
    url: 'index.php?X=1', 
    success: function (resp) { 
     var t = Ext.decode(resp.responseText); 
     root = Ext.getCmp('tree-panel').getRootNode(); //get the root node 
     for (i = 0; i < t.length; i++) { 
      root.appendChild({ 
       id: i, 
       text: t[i], 
       leaf: true 
      }); //add childs 
     } 
     Ext.get(document.body).unmask(); 
    } 
}); 

我可以看到它的easer。 NodeInterface有其他更有用的方法:)

+0

+1好信息。幫了我很多! – 2012-08-22 23:35:26