亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

JavaScript的ExtJS框架中數面板TreePanel的使用實例解析

2019-11-20 09:58:32
字體:
來源:轉載
供稿:網友

在ExtJS中,不管是葉子節點還是非葉子節點,都統一用TreeNode表示樹的節點。在ExtJS中,有兩種類型的樹節點。一種節點是普通的簡單樹 節點,由Ext.tree.TreeNode定義,另外一種是需要異步加載子節點信息的樹節點,該類由Ext.tree.AsyncTreeNode定 義。
在數據中, text 顯示文字, leaf 節點 , children 子節點,expanded 展開

var store = Ext.create(‘Ext.data.TreeStore', {root: {expanded: true,children: [{ text: “留學”, leaf: true },{ text: “功課”, expanded: true, children: [{ text: “英語”, leaf: true },{ text: “代數”, leaf: true}] },{ text: “托福”, leaf: true }]}});

TreePanel從servlet中讀取JSON數據
在Ext JS的Tree中的數據往往是從服務器端的動態程序中獲取的。
為了獲取數據,我們可以先編寫一個返回JSON的Servlet共前臺的樹形組建訪問:
服務器端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組建中設置的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);}}

現在就可以在前臺的TreePanel組建的loader方法中訪問上面創建的servlet了,代碼如下:
客戶端顯示代碼

Ext.onReady(function(){var tree = new Ext.tree.TreePanel({//這里的div-tree是在html中創建的一個對象的id值el: 'div-tree',//使用loader方法訪問TreeNodeServletloader: new Ext.tree.TreeLoader({dataUrl:'../TreeNodeServlet'})});var root = new Ext.tree.AsyncTreeNode({id:'0',text:'0'})tree.setRootNode(root);tree.render();root.expand();});

效果圖如下:

2016521110621249.png (266×168)

在樹TreePanel之間拖放結點
有時候我們在程序中,需要把一棵TreePanel的元素拖放到另外一棵TreePanel中,如果是在同一棵樹中拖動時設置組件的enableDD參數為true,而現在需要在不同給的書之間拖動元素,這個時候就可以設置組件的enableDrag和enableDrop參數,詳細示例如下:

1.編寫JS代碼:
JS代碼

Ext.onReady(function(){  var tree1 = new Ext.tree.TreePanel({    el: 'tree1', //這里設置enableDrag為true表示可以從這里拖動元素到別處    enableDrag:true,    loader: new Ext.tree.TreeLoader({dataUrl: 'treeData1.txt'})  });  var tree2 = new Ext.tree.TreePanel({    el: 'tree2', //這里設置enableDrop為true表示可以在這棵樹中放置拖動過來的元素    enableDrop:true,    loader: new Ext.tree.TreeLoader({dataUrl: 'treeData2.txt'})  });  var root1 = new Ext.tree.AsyncTreeNode({text:'跟節點'});  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文件,里面的數據為JSON格式:
treeData1.txt:

[    {text:'非葉子結點'},    {text:'葉子結點',leaf:true}]treeData2.txt:[  {text:'計算機',children:[    {text:'Java',children:[      {text:'Java核心技術',leaf:true},      {text:'Thinking in Java',leaf:true}    ]},    {text:'算法導論',leaf:true}  ]},  {text:'音樂',children:[    {text:'樂理基礎',leaf:true},    {text:'卡爾卡西古典吉他教程',leaf:true}    ]}]

4.程序效果如下圖所示:

2016521110709614.png (531×309)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久久久久久久亚洲| 久久久久久国产| 欧美人在线视频| 日韩免费在线播放| 亚洲国产精品系列| 国产精品热视频| 日韩av电影中文字幕| 夜夜躁日日躁狠狠久久88av| 国产一区在线播放| 97视频在线观看免费高清完整版在线观看| 精品久久久久久中文字幕一区奶水| 色老头一区二区三区在线观看| 国产精品免费小视频| 欧美电影在线观看网站| 97久久久免费福利网址| 欧美成人午夜激情| 久久精品91久久香蕉加勒比| 国产精品九九九| 亚洲女人天堂av| 欧美理论电影在线观看| 色噜噜久久综合伊人一本| 国产美女精品视频免费观看| 国产亚洲综合久久| 欧美国产日韩一区二区三区| 91啪国产在线| 91精品国产自产在线| 欧美一级片久久久久久久| 久久影院资源网| 中文字幕国产精品久久| 欧美乱大交xxxxx| 国产啪精品视频网站| 久久久久久久国产精品| 中文字幕日韩视频| 日韩av片永久免费网站| 中文字幕欧美日韩在线| 亚洲视频综合网| 国产精品福利在线观看网址| 亚洲女成人图区| 日韩中文字幕免费| 91精品在线国产| 亚洲精品99999| 亚洲欧洲自拍偷拍| 欧美疯狂做受xxxx高潮| www.欧美精品| 国产精品一区二区在线| 亚洲第一区中文99精品| 久久久免费av| 亚洲国产日韩欧美综合久久| 欧美巨大黑人极品精男| 91人人爽人人爽人人精88v| 国产日韩欧美视频在线| www国产亚洲精品久久网站| 精品国内亚洲在观看18黄| 国产欧美一区二区三区久久| 亚洲欧美在线一区| 国产亚洲一区二区精品| 日韩在线中文字幕| 国产日韩在线观看av| 午夜精品久久久久久99热| 性日韩欧美在线视频| 精品视频久久久久久| 国产精品视频成人| 亚洲乱码一区av黑人高潮| 国产97人人超碰caoprom| 亚洲第一网中文字幕| 久久五月天色综合| 欧美另类第一页| 亚洲一区免费网站| 亚洲视频在线免费观看| 亚洲视频专区在线| 91av在线看| 成人av资源在线播放| 26uuu亚洲国产精品| www.久久撸.com| 国产精品露脸av在线| 亚洲缚视频在线观看| 久久夜色精品国产欧美乱| 日本亚洲欧洲色| 国产精品一区二区三区在线播放| 国外成人免费在线播放| 欧美孕妇毛茸茸xxxx| 久久久久久午夜| 欧美国产精品va在线观看| 亚洲欧美中文字幕在线一区| 欧美日韩免费看| 狠狠色噜噜狠狠狠狠97| 久久精品久久精品亚洲人| 欧美激情免费看| 亚洲色图综合网| 国产精品永久免费视频| 国产日韩在线免费| 日韩av影片在线观看| 精品视频在线播放色网色视频| 91免费高清视频| 日韩av电影在线网| 亚洲精品一区久久久久久| 日本乱人伦a精品| 亚洲丝袜在线视频| 91国在线精品国内播放| 中文字幕亚洲国产| 亚洲综合中文字幕在线观看| 国产亚洲欧美日韩精品| 欧美日韩亚洲91| 成人午夜在线影院| 亚洲天堂精品在线| 日韩av在线看| 国产999在线观看| 亚洲精品99久久久久| 欧美日韩亚洲精品一区二区三区| 在线精品播放av| 亚洲午夜国产成人av电影男同| 国产精品久久久久久av福利| 成人性生交xxxxx网站| 亚洲一区av在线播放| 欧美理论电影在线观看| 日韩精品欧美国产精品忘忧草| 青草青草久热精品视频在线网站| 亚洲国产91色在线| 富二代精品短视频| 国产做受69高潮| 欧美极品第一页| 91九色国产在线| 国产精品成人av在线| 亚洲精品99999| 尤物yw午夜国产精品视频| 日韩成人在线免费观看| 日韩亚洲精品电影| 91精品久久久久久久久久另类| 日韩欧美国产激情| 国产精品入口日韩视频大尺度| 欧美资源在线观看| 欧美大片免费看| 欧美第一页在线| 国产午夜精品全部视频在线播放| 国产精品福利观看| 欧美激情视频一区| 成人精品视频99在线观看免费| 中文字幕v亚洲ⅴv天堂| 国产精品1区2区在线观看| 久久国产精品偷| 高潮白浆女日韩av免费看| 91av在线播放| 日韩在线欧美在线国产在线| 欧美精品videos| 国产91精品视频在线观看| 欧美中文在线视频| 在线观看国产精品91| 亚洲国产私拍精品国模在线观看| 日韩成人黄色av| 欧美日韩亚洲精品内裤| 久久99国产精品久久久久久久久| 亚洲欧美日韩第一区| 久久精品国产91精品亚洲| 日韩免费在线电影| 欧美高清视频在线| 亚洲精品美女久久久| 国产精品免费一区| 青青久久aⅴ北条麻妃| 俺也去精品视频在线观看| 亚洲男人的天堂在线| 日韩女优人人人人射在线视频| 国产精品精品久久久久久| 一区二区三区高清国产| 日本精品中文字幕|