JavaScript的ExtJS框架中數(shù)面板TreePanel的使用實(shí)例解析
在ExtJS中,不管是葉子節(jié)點(diǎn)還是非葉子節(jié)點(diǎn),都統(tǒng)一用TreeNode表示樹的節(jié)點(diǎn)。在ExtJS中,有兩種類型的樹節(jié)點(diǎn)。一種節(jié)點(diǎn)是普通的簡單樹 節(jié)點(diǎn),由Ext.tree.TreeNode定義,另外一種是需要異步加載子節(jié)點(diǎn)信息的樹節(jié)點(diǎn),該類由Ext.tree.AsyncTreeNode定 義。
在數(shù)據(jù)中, text 顯示文字, leaf 節(jié)點(diǎn) , children 子節(jié)點(diǎn),expanded 展開
var store = Ext.create(‘Ext.data.TreeStore', {
root: {
expanded: true,
children: [
{ text: “留學(xué)”, leaf: true },
{ text: “功課”, expanded: true, children: [
{ text: “英語”, leaf: true },
{ text: “代數(shù)”, leaf: true}
] },
{ text: “托?!? leaf: true }
]
}
});
TreePanel從servlet中讀取JSON數(shù)據(jù)
在Ext JS的Tree中的數(shù)據(jù)往往是從服務(wù)器端的動態(tài)程序中獲取的。
為了獲取數(shù)據(jù),我們可以先編寫一個返回JSON的Servlet共前臺的樹形組建訪問:
服務(wù)器端servlet代碼:
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
public class TreeNodeServlet extends HttpServlet {
protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
//這里的node是前臺的AsyncTreeNode組建中設(shè)置的ID,見下面的JS程序
String treeNode = request.getParameter("node");
String json = "";
PrintWriter out = response.getWriter();
if("0".equals(treeNode)) {
json+="[{id:1,text:'0-1'},{id:2,text:'0-2'}]";
}
else if("1".equals(treeNode)) {
json+="[{id:11,text:'0-1-1',leaf:true},{id:12,text:'0-1-2',leaf:true}]";
}
else if("2".equals(treeNode)) {
json+="[{id:21,text:'0-2-1'},{id:22,text:'0-2-2',leaf:true}]";
}
else if("21".equals(treeNode)) {
json+="[{id:211,text:'0-2-1-1',leaf:true},{id:212,text:'0-2-1-2',leaf:true}]";
}
out.write(json);
}
}
現(xiàn)在就可以在前臺的TreePanel組建的loader方法中訪問上面創(chuàng)建的servlet了,代碼如下:
客戶端顯示代碼
Ext.onReady(function(){
var tree = new Ext.tree.TreePanel({
//這里的div-tree是在html中創(chuàng)建的一個對象的id值
el: 'div-tree',
//使用loader方法訪問TreeNodeServlet
loader: new Ext.tree.TreeLoader({dataUrl:'../TreeNodeServlet'})
});
var root = new Ext.tree.AsyncTreeNode({id:'0',text:'0'})
tree.setRootNode(root);
tree.render();
root.expand();
});
效果圖如下:

在樹TreePanel之間拖放結(jié)點(diǎn)
有時候我們在程序中,需要把一棵TreePanel的元素拖放到另外一棵TreePanel中,如果是在同一棵樹中拖動時設(shè)置組件的enableDD參數(shù)為true,而現(xiàn)在需要在不同給的書之間拖動元素,這個時候就可以設(shè)置組件的enableDrag和enableDrop參數(shù),詳細(xì)示例如下:
1.編寫JS代碼:
JS代碼
Ext.onReady(function(){
var tree1 = new Ext.tree.TreePanel({
el: 'tree1',
//這里設(shè)置enableDrag為true表示可以從這里拖動元素到別處
enableDrag:true,
loader: new Ext.tree.TreeLoader({dataUrl: 'treeData1.txt'})
});
var tree2 = new Ext.tree.TreePanel({
el: 'tree2',
//這里設(shè)置enableDrop為true表示可以在這棵樹中放置拖動過來的元素
enableDrop:true,
loader: new Ext.tree.TreeLoader({dataUrl: 'treeData2.txt'})
});
var root1 = new Ext.tree.AsyncTreeNode({text:'跟節(jié)點(diǎn)'});
var root2 = new Ext.tree.AsyncTreeNode({text:'圖書'});
tree1.setRootNode(root1);
tree2.setRootNode(root2);
tree1.render();
tree2.render();
});
2.HTML代碼如下:
HTML代碼
<div id="tree1"></div> <div id="tree2"></div>
3.編寫兩個TreeLoader需要裝載的txt文件,里面的數(shù)據(jù)為JSON格式:
treeData1.txt:
[
{text:'非葉子結(jié)點(diǎn)'},
{text:'葉子結(jié)點(diǎn)',leaf:true}
]
treeData2.txt:
[
{text:'計(jì)算機(jī)',children:[
{text:'Java',children:[
{text:'Java核心技術(shù)',leaf:true},
{text:'Thinking in Java',leaf:true}
]},
{text:'算法導(dǎo)論',leaf:true}
]},
{text:'音樂',children:[
{text:'樂理基礎(chǔ)',leaf:true},
{text:'卡爾卡西古典吉他教程',leaf:true}
]}
]
4.程序效果如下圖所示:

相關(guān)文章
學(xué)習(xí)ExtJS TextField常用方法
ExtJS TextField常用方法2009-10-10
javascript Ext JS 狀態(tài)默認(rèn)存儲時間
通過ExtJS的源碼可以知道,ExtJS將Grid的自定義顯示列等自定義狀態(tài)信息存入Cookie中,默認(rèn)時間為7天2009-02-02
ExtJS[Desktop]實(shí)現(xiàn)圖標(biāo)換行示例代碼
ExtJS中的desktop的demo中,默認(rèn)的圖標(biāo)排列是不換行的,以下代碼就是為了解決這一問題的,需要的朋友可以了解下2013-11-11
extjs4 treepanel動態(tài)改變行高度示例
本文為大家介紹下extjs4 treepanel如何動態(tài)改變行高度,下面有個不錯的示例,感興趣的朋友可以參考下2013-12-12
基于ExtJs在頁面上window再調(diào)用Window的事件處理方法
下面小編就為大家?guī)硪黄贓xtJs在頁面上window再調(diào)用Window的事件處理方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-07-07
Extjs的FileUploadField文件上傳出現(xiàn)了兩個上傳按鈕
Extjs的FileUploadField文件上傳在頁面中出現(xiàn)了兩個上傳按鈕,這個是和ext的本身css的樣式有關(guān)系,所以要將樣式修改下2014-04-04
Extjs中通過Tree加載右側(cè)TabPanel具體實(shí)現(xiàn)
用Extjs4.1來做界面,有關(guān)Extjs4.1資料在網(wǎng)上也相對來說較少,下面是具體的實(shí)現(xiàn)代碼1.左側(cè)的功能樹2.需要打開的對應(yīng)的view,有類似需求的朋友可以參考下哈2013-05-05

