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

首頁 > 編程 > JavaScript > 正文

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

2019-11-19 18:17:12
字體:
來源:轉載
供稿:網友

本文實例講述了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"  }]

PS:這里再為大家提供幾款關于xml操作的在線工具供大家參考使用:

在線XML/JSON互相轉換工具:
http://tools.VeVB.COm/code/xmljson

在線格式化XML/在線壓縮XML:
http://tools.VeVB.COm/code/xmlformat

XML在線壓縮/格式化工具:
http://tools.VeVB.COm/code/xml_format_compress

XML代碼在線格式化美化工具:
http://tools.VeVB.COm/code/xmlcodeformat

更多關于JavaScript相關內容可查看本站專題:《JavaScript操作XML文件技巧總結》、《JavaScript中json操作技巧總結》、《JavaScript查找算法技巧總結》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 五常市| 邢台市| 疏附县| 望城县| 华宁县| 枞阳县| 蒲城县| 田阳县| 天津市| 武宁县| 绵竹市| 怀仁县| 团风县| 桑日县| 康定县| 哈密市| 疏勒县| 沅江市| 保亭| 康乐县| 噶尔县| 遂昌县| 论坛| 祥云县| 鄂尔多斯市| 峨边| 通榆县| 玉树县| 尚义县| 怀宁县| 绥中县| 永定县| 沾化县| 万宁市| 崇州市| 启东市| 临沧市| 拜泉县| 左贡县| 伊宁县| 石首市|