<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    一個基于xml 得Ext treepanel

    Posted on 2008-12-30 11:23 Robert Su 閱讀(944) 評論(0)  編輯  收藏 所屬分類: ExtJS
    /**
        Create an Ext.tree.TreePanel in the passed Element using
        an XML document from the passed URL, calling the passed
        callback on completion.
        @param el {String/Element/HtmlElement} The tree's container.
        @param url {String} The URL from which to read the XML
        @param callback {function:tree.render} The function to call on completion,
            defaults to rendering the tree.
    */
    function createXmlTree(el, url, callback) {
        
    var tree = new Ext.tree.TreePanel(el);
        
    var p = new Ext.data.HttpProxy({url:url});
        p.on(
    "loadexception"function(o, response, e) {
            
    if (e) throw e;
        });
        p.load(
    null, {
            read: 
    function(response) {
                
    var doc = response.responseXML;
                tree.setRootNode(treeNodeFromXml(doc.documentElement 
    || doc));
            }
        }, callback 
    || tree.render, tree);
        
    return tree;
    }
     
    /**
        Create a TreeNode from an XML node
    */
    function treeNodeFromXml(XmlEl) {
    //    Text is nodeValue to text node, otherwise it's the tag name
        var t = ((XmlEl.nodeType == 3? XmlEl.nodeValue : XmlEl.tagName);

    //    No text, no node.
        if (t.replace(/\s/g,'').length == 0) {
            
    return null;
        }
        
    var result = new Ext.tree.TreeNode({
            text : t
        });

    //    For Elements, process attributes and children
        if (XmlEl.nodeType == 1) {
            Ext.each(XmlEl.attributes, 
    function(a) {
                
    var c = new Ext.tree.TreeNode({
                    text: a.nodeName
                });
                c.appendChild(
    new Ext.tree.TreeNode({
                    text: a.nodeValue
                }));
                result.appendChild(c);
            });
            Ext.each(XmlEl.childNodes, 
    function(el) {
    //        Only process Elements and TextNodes
                if ((el.nodeType == 1|| (el.nodeType == 3)) {
                    
    var c = treeNodeFromXml(el);
                    
    if (c) {
                        result.appendChild(c);
                    }
                }
            });
        }
        
    return result;
    }

    回頭有空添加詳細注解~~原文中6樓有更詳細的解答  http://extjs.com/forum/showthread.php?t=3987




    posts - 103, comments - 104, trackbacks - 0, articles - 5

    Copyright © Robert Su

    主站蜘蛛池模板: 相泽亚洲一区中文字幕| 国产成人99久久亚洲综合精品| 亚洲AV无码专区亚洲AV伊甸园| 黄色a三级免费看| 亚洲成a人片在线观看日本麻豆| 亚洲日本VA中文字幕久久道具| 成年女人视频网站免费m| 亚洲一级毛片视频| 91嫩草国产在线观看免费| 最新国产成人亚洲精品影院| 国产成人免费网站| 亚洲成AV人片在WWW| 国产成人免费a在线视频色戒| 色天使亚洲综合一区二区| 亚洲AV无码一区二区三区国产| 一级毛片不卡免费看老司机| 国产亚洲美日韩AV中文字幕无码成人| kk4kk免费视频毛片| 国产精品亚洲成在人线| 中国人xxxxx69免费视频| 最新国产成人亚洲精品影院| 日本媚薬痉挛在线观看免费| 曰批全过程免费视频观看免费软件| 亚洲国产午夜中文字幕精品黄网站| 国产精品1024在线永久免费| 亚洲ⅴ国产v天堂a无码二区| 30岁的女人韩剧免费观看| 亚洲熟妇无码AV| 国产亚洲精品线观看动态图| 1a级毛片免费观看| 亚洲av无码成人精品区一本二本| 亚洲综合AV在线在线播放| 59pao成国产成视频永久免费| 亚洲成AV人片在WWW| 亚洲av日韩综合一区在线观看| 无码乱肉视频免费大全合集| 国产亚洲美女精品久久久久| 久久精品国产亚洲| 免费观看理论片毛片| 国产精品青草视频免费播放| 亚洲国产模特在线播放|