国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

js實現的xml對象轉json功能示例

2024-05-06 16:34:07
字體:
來源:轉載
供稿:網友

本文實例講述了js實現的xml對象轉json功能。分享給大家供大家參考,具體如下:

支持無限級別xml結構對象轉json,并且支持任意標簽屬性轉json(兼容ie8等瀏覽器)?

xml字符串轉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對象*xmlObj:xml對象*nodename:節點路徑('ROOT/ITEM')*isarray:true,強制返回數組對象**/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 xmlstr="<USERS>" +        "<USER state='0'>" +        "<USERNAME type='String'>張三</USERNAME>" +        "<USERID type='String'>00001</USERID>" +        "</USER>" +        "<USER state='1'>" +        "<USERNAME type='String' size='100'>李四</USERNAME>" +        "<USERID>00002</USERID>" +        "</USER>" +        "<USER>" +        "<USERNAME>李四</USERNAME>" +        "<USERID>00002</USERID>" +        "</USER>" +        "</USERS>";var xmlobj=loadXml(xmlstr);

參數設置:

(1)  xmltojson(xmlobj);//返回結果如下

{  "USERS": {    "USER": [      {        "state": "0",        "USERNAME": {          "type": "String"        },        "length": 1,        "USERID": {          "type": "String"        }      },      {        "state": "1",        "USERNAME": {          "type": "String",          "size": "100"        },        "length": 1,        "USERID": "00002"      },      {        "USERNAME": "李四",        "length": 1,        "USERID": "00002"      }    ],    "length": 1  }}

(2)xmltojson(xmlobj,'USERS/USER',true);返回結果如下:

[  {   "state": "0",   "USERNAME": {     "type": "String"   },   "length": 1,   "USERID": {     "type": "String"   }  },  {   "state": "1",   "USERNAME": {     "type": "String",     "size": "100"   },   "length": 1,   "USERID": "00002"  },  {   "USERNAME": "李四",   "length": 1,   "USERID": "00002"  }]

希望本文所述對大家JavaScript程序設計有所幫助。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 鄂托克前旗| 都安| 祁阳县| 通山县| 保定市| 资兴市| 和田县| 阿图什市| 大埔县| 江口县| 泌阳县| 兰坪| 怀来县| 九寨沟县| 开平市| 屯门区| 陕西省| 萝北县| 邳州市| 松溪县| 淮安市| 眉山市| 徐州市| 息烽县| 临朐县| 宜兰市| 平顶山市| 盐城市| 苍山县| 阳曲县| 武乡县| 黔江区| 乐亭县| 和林格尔县| 清徐县| 通城县| 上思县| 灵宝市| 高邑县| 会昌县| 高台县|