<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 閱讀(938) 評論(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

    主站蜘蛛池模板: 久久久精品免费视频| 一级做α爱过程免费视频| 免费91麻豆精品国产自产在线观看| 免费一级毛片一级毛片aa| 在线aⅴ亚洲中文字幕| 午夜宅男在线永久免费观看网 | 又大又黄又粗又爽的免费视频| 在线精品亚洲一区二区| 免费无码又爽又刺激高潮的视频| 中文有码亚洲制服av片| 日韩在线看片免费人成视频播放| 亚洲AV无码资源在线观看| 国产乱弄免费视频| 久久高潮一级毛片免费| 亚洲Av永久无码精品三区在线| 美女视频黄a视频全免费网站色窝| 久久久久亚洲AV无码永不| 在线看片免费人成视久网| 亚洲一区二区三区91| 女人让男人免费桶爽30分钟| 男男gvh肉在线观看免费| 亚洲一区二区精品视频| 88av免费观看| 亚洲色精品三区二区一区| 亚洲M码 欧洲S码SSS222| 好久久免费视频高清| 亚洲永久在线观看| 国产成人免费a在线视频色戒| xxxx日本在线播放免费不卡| 亚洲av色影在线| 成人免费毛片观看| 亚洲国产免费综合| 亚洲欧洲日产国码二区首页| 国产精品jizz在线观看免费| a级毛片高清免费视频| 亚洲国产中文在线二区三区免| 国产精品久免费的黄网站| 久草视频在线免费看| 久久精品国产亚洲AV天海翼| 亚洲爆乳无码专区| 日韩一区二区三区免费体验|