<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

    主站蜘蛛池模板: 中文在线日本免费永久18近| 亚洲综合丁香婷婷六月香| 免费国产污网站在线观看15| 亚洲欧美日韩一区二区三区| 亚洲啪啪综合AV一区| 男男AV纯肉无码免费播放无码| 一级做a爰片久久毛片免费陪 | 伊人久久免费视频| 免费国产va视频永久在线观看| 国产精品亚洲精品青青青| 亚洲成人激情在线| 亚洲成av人片天堂网| 亚洲韩国精品无码一区二区三区| 日韩一品在线播放视频一品免费| 国产妇乱子伦视频免费| 国产一区二区免费视频| 日本免费电影一区二区| 插鸡网站在线播放免费观看| 免费国产黄网站在线观看动图| 亚洲av无码专区在线电影天堂| 亚洲AV综合色区无码二区爱AV| 亚洲精品福利网站| 亚洲日本视频在线观看| 亚洲avav天堂av在线网爱情| 亚洲不卡影院午夜在线观看| 亚洲精品在线播放视频| 亚洲女人18毛片水真多| 亚洲日韩国产二区无码| 久久亚洲精品成人无码| 9久热精品免费观看视频| 国产免费拔擦拔擦8X高清在线人| 久久久免费精品re6| 成年人性生活免费视频| 亚洲人午夜射精精品日韩| 久久亚洲成a人片| 亚洲日韩国产二区无码 | 国产国产人免费人成免费视频 | 国产亚洲综合视频| 日韩免费视频一区二区| 国产精品免费视频一区| 亚洲男同帅GAY片在线观看|