首頁 > web前端 > js教程 > 主體

javascript xml怎麼轉json

藏色散人
發布: 2023-01-05 16:11:49
原創
5322 人瀏覽過

javascript xml轉json的方法:先透過「loadXml(str) {...}」載入xml資料;然後透過「xmlTojson(xmlObj, nodename,isarray){..}」將xml資料轉成json物件的資料即可。

javascript xml怎麼轉json

本文操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

1、程式碼

//加载xml数据
    function loadXml(str) {
        if (str == null) {
            return null;
        }
        var doc = str;
        try{
            doc = createXMLDOM();
            doc.async = false;
            doc.loadXML(str);
        }catch(e){
            doc = $.parseXML(str);
        }
        return doc;
    }

    //xml数据转成json对象的数据
    function xmlTojson(xmlObj, nodename, isarray){
        var obj = $(xmlObj);
        var itemobj = {};
        var nodenames = "";
        var getAllAttrs = function(node){//递归解析xml 转换成json对象
            var _itemobj = {};
            var notNull = false;
            var nodechilds = node.childNodes;
            var childlenght = nodechilds.length;
            var _attrs = node.attributes;
            var firstnodeName = "#text";
            try{
                firstnodeName = nodechilds[0].nodeName;
            }catch(e){

            }
            if((childlenght > 0 && firstnodeName != "#text") || _attrs.length > 0){
                var _childs = nodechilds;
                var _childslength = nodechilds.length;
                var _fileName_ = "";
                if(undefined != _attrs){
                    var _attrslength = _attrs.length;
                    for(var i = 0; i < _attrslength; i++){//解析xml节点属性
                        var attrname = _attrs[i].nodeName;
                        var attrvalue = _attrs[i].nodeValue;
                        _itemobj[attrname] = attrvalue;
                    }
                }
                for (var j = 0; j < _childslength; j++) {//解析xml子节点
                    var _node = _childs[j];
                    var _fildName = _node.nodeName;
                    if("#text" == _fildName){break;};
                    if(_itemobj[_fildName] != undefined){//如果有重复的节点需要转为数组格式
                        if(!(_itemobj[_fildName] instanceof Array)){
                            var a = _itemobj[_fildName];
                            _itemobj[_fildName] = [a];//如果该节点出现大于一个的情况 把第一个的值存放到数组中
                        }
                    }
                    var _fildValue = getAllAttrs(_node);
                    try{
                        _itemobj[_fildName].push(_fildValue);
                    }catch(e){
                        _itemobj[_fildName] = _fildValue;
                        _itemobj["length"] = 1;
                    }
                }
           }else{
                _itemobj = (node.textContent == undefined) ? node.text : node.textContent;
           }
           return _itemobj;
        };

        if(nodename){
            nodenames = nodename.split("/")
        }
        for(var i = 0;i < nodenames.length; i++){
            obj = obj.find(nodenames[i]);
        }
        $(obj).each(function(key, item){
            if(itemobj[item.nodeName] != undefined){
                if(!(itemobj[item.nodeName] instanceof Array)){
                    var a = itemobj[item.nodeName];
                    itemobj[item.nodeName] = [a];
                }
                itemobj[item.nodeName].push(getAllAttrs(item));
            }else{
                if(nodenames.length > 0){
                    itemobj[item.nodeName] = getAllAttrs(item);
                }else{
                    itemobj[item.firstChild.nodeName] = getAllAttrs(item.firstChild);
                }
            }
        });

        if(nodenames.length > 1){
            itemobj = itemobj[nodenames[nodenames.length-1]];
        }
        if(isarray && !(itemobj instanceof Array) && itemobj != undefined){
            itemobj = [itemobj];
        }
        return itemobj;
    }
    
    //实例测试
    var dataStr = &#39;<userList><user name="aa" age="32"></user><user name="bb" age="33"></user><user name="cc" age="34"><child name="cc-1" age="3"></child></user></userList>&#39;
    var xmlObj = loadXml(dataStr);
    var jsonData = xmlTojson(xmlObj, &#39;userList/user&#39;, true);
    console.log(jsonData)
登入後複製

2、測試結果

#【推薦學習:javascript高級教程

 

以上是javascript xml怎麼轉json的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板