天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

學習YUI.Ext 第六天--關于樹TreePanel(Part 2異步獲取節點)

下面將介紹如何異步取一棵樹的所有節點,具體做法與官方同步取節點有很大不同,尤其在json的id屬性上,下面是我一些摸索,可能不是最佳方案,有待大家一起研究。
異步取節點的思路是這樣的:
1、先定義一個初始化節點(也可以不定義,看個人需求)
2、yui-ext根據該節點id請求服務器,獲得子節點各屬性
3、循環
特點:可以在上一級目錄中,在服務器端預先將該節點是否有子節點讀好(json中的isLeaf屬性),雖然但數據庫將多承擔一些壓力,但用個count(*)不會造成太大負擔(除非查詢條件異常復雜),也可以不讀,即把所有isLeaf設置為false。
問題:
1、目前還無法進行reload,即每次打開節點都重新讀取一次
2、樣式還有些問題,無法通過node. childNodes[i]設置子節點的style,所以無法改變最后一級元素的style(也許是通過別的途徑改變style的?)
示例:
先給出一段js代碼,可以結合官方的demo(http://yui-ext.com/playpen/yui-ext.0.40/examples/tree/reorder.html)看看:
//定義根id的變量
復制代碼 代碼如下:
var rootId = 1; 
var TreeTest = function(){ 
    // shorthand 
    var Tree = YAHOO.ext.tree; 

    return { 
        init : function(userName){ 
            var tree = new Tree.TreePanel('detailTree', { 
                animate:true,  
                //這個dataUrl是初始化樹所用的url,你也可以不寫或定義一個靜態json文件,還可以什么都不寫全部依賴于第二個url自動產生,視具體需求而定 
                loader: new Tree.TreeLoader({dataUrl:'calendarDetail.do?method=getDayDetailJSON&parentId='+rootId}), 
                enableDD:true, 
                containerScroll: true 
            }); 

            // set the root node 
            var root = new Tree.AsyncTreeNode({ 
                text: 'yui-ext',  
                draggable:false,  
                id:rootId 
            }); 
            tree.setRootNode(root); 

            //根據當前節點id,動態拼出請求服務器的路徑 
            //每產生一個節點,指向一個事件的引用,將新建loader.dataUrl(具體事件的機制還需要再研究) 
            //注意調用函數是beforeload 
            tree.on('beforeload', function(node){  
                tree.loader.dataUrl = 'calendarDetail.do?method=getDayDetailJSON&parentId='+node.id; 
            }); 

             
            //這里演示一個自定義json的用法(description為自定義json的key) 
            //以及如何定義某節點的style(node.ui.textNode.style.title) 
            //具體可以看ui這個類 
            tree.on('beforeexpand', function(node){  
                node.ui.textNode.style.title = ‘red'; 
                alert(node.attributes.description); 
            });                                         

            // render the tree 
            tree.render(); 

            // false for not recursive (the default), false to disable animation 
            root.expand(); 
        } 
    }; 
}(); 

同時再分析一個json:
復制代碼 代碼如下:
[{"text":"衣服類",   
"id":"5",     //注意:這里是該節點的id,拼連接時要用到,與官方的json有所不同  
"leaf":true, 
"cls":"file", 
"description":"這里是衣服類"}]   //自定義只需要這樣就可以了  
給出Java產生json的代碼邏輯片斷:  
…… 
//list為由傳入的id所求的category集合 
List list=  
findBy("parentId", new Long(parentId.toString())); 
StringBuffer JSONStr = new StringBuffer();  //聲明json 
JSONStr.append("["); 

for(CostCategory i : list){   
    boolean isLeaf = isLeaf(i.getId());  //isLeaf()為判斷是否有以該id為parentId的節點,具體沒有給出 
    String icon = isLeaf?"file":"folder"; 
    String description = i.getCategoryDescription()==null?"":i.getCategoryDescription(); 
    //{"text":"treedata.jsp","id":"treedata.jsp","leaf":true,"cls":"file"}, 
    JSONStr.append("{/"text/":/""+ 
            i.getCategoryName()+"/",/"id/":/""+ 
            i.getId()+"/",/"leaf/":"+ 
            isLeaf+",/"cls/":/""+ 
            icon+"/",/"description/":/""+ 
            description+"/"},"); 

JSONStr.deleteCharAt(JSONStr.lastIndexOf(",")); 
JSONStr.append("]"); 
System.out.println(JSONStr); 
out.print(JSONStr);   //輸出json 
…… 

JavaScript技術學習YUI.Ext 第六天--關于樹TreePanel(Part 2異步獲取節點),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久久精品久久 | 5580免费午夜福利院 | 国产私拍福利精品视频 | 九九热视频免费观看 | japansemature护士 JAPANRCEP老熟妇乱子伦视频 | 国产人妻人伦精品久久无码 | 麻豆蜜桃国语精品无码视频 | 中俄两军在日本海等上空战略巡航 | 国产成人在线视频网站 | 美女内射少妇一区二区四区 | 猪蜜蜜网站在线观看电视剧 | 美娇妻的性奴史1一4 | 日韩欧美亚洲精品综合在线 | 中文字幕在线播放视频 | 张开腿我尝尝你的草莓 | 好色的妹妹 | 青春草国产成人精品久久 | 动漫人物差差差30分钟免费看 | 美女国产毛片A区内射 | 中文字幕一区二区三区在线观看 | 亚洲人成色777777老人头 | 国产在线精品亚洲另类 | 亚洲欧美成人无码久久久 | 伊人免费在线 | 国产精品自产拍在线观看中文 | 乱码AV午夜噜噜噜噜 | 亚洲a视频在线 | 国产成人啪精品视频免费网 | 丝袜美女被艹 | 亚洲a视频在线观看 | 高H高肉强J短篇校园 | 美女张开腿让男人桶爽无弹窗 | 欧美成人一区二免费视频 | 日产亚洲一区二区三区 | 亚洲人成无码久久久AAA片 | 精选国产AV精选一区二区三区 | 狠狠色香婷婷久久亚洲精品 | 岛国大片在线播放高清 | 超碰97超碰在线视频哦 | 北条麻妃のレズナンパ | 成年黄网站免费大全毛片 |