JavaScript实现的XML与JSON互转功能详解_javascript技巧_脚本之家

更多关于JavaScript相关内容可查看本站专题:《JavaScript中ajax操作技巧总结》、《JavaScript操作XML文件技巧总结》、《JavaScript中json操作技巧总结》、《JavaScript错误与调试技巧总结》及《JavaScript数据结构与算法技巧总结》

最近在开发在线XML编辑器,打算使用JSON做为中间格式。因为JSON相对于XML,有着容易阅读、解析速度快、占用空间小等优点,更易于在WEB上传递数据。但在实际使用中还是发现了一些易于忽略的细节,对于需要严格保证XML原始结构的情况,在转换成JSON时需要一些注意。

PS:这里再为大家提供几款关于xml与json操作的在线工具供大家参考使用:

另外,形如下面的代码,使用上文提到的脚本进行转换,也会导致无法正确还原的情况。

JSON在线格式化工具:

在线格式化XML/在线压缩XML:

{ "article": [ { "section": { "#text": "第一节", "@id": "s1" }, }, { "header": { "#text": "标题", "@id": "h1" } }, { "section": { "#text": "第一节", "@id": "s2" } } ]}

而第2个脚本jsonxml,在上面这种“文本混合标签”的情况下,没有将标签提取出来,而是转换成了下面这种格式。

{ items: { item: { zip_cd: "1000001" us_state: "NY", us_city: "New York", us_dist: "Broadway", } }};

// Changes XML to JSONfunction xmlToJson { // Create the return object var obj = {}; if  { // element // do attributes if (xml.attributes.length > 0) { obj["@attributes"] = {}; for (var j = 0; j < xml.attributes.length; j++) { var attribute = xml.attributes.item; obj["@attributes"][attribute.nodeName] = attribute.nodeValue; } } } else if  { // text obj = xml.nodeValue; } // do children if  { for(var i = 0; i < xml.childNodes.length; i++) { var item = xml.childNodes.item; var nodeName = item.nodeName; if  == "undefined") { obj[nodeName] = xmlToJson; } else { if (typeof == "undefined") { var old = obj[nodeName]; obj[nodeName] = []; obj[nodeName].push; } obj[nodeName].push; } } } return obj;};

说了半天下面整理了一个例子

用Js将XML转换成JSON的脚本,在网上找了一些现成的脚本,但大都只满足比较简单的情况,都不可以完成保证原始结构的互转。下面是从网上找到的一些脚本或者文章:

希望本文所述对大家JavaScript程序设计有所帮助。

…becomes workable a JavaScript object with the following structure:

XML转换成JSON的格式大概如下:

JKL.ParseXML :

在线XML/JSON互相转换工具:

function xmlToJson {// Create the return objectvar obj = {};if  { // element// do attributesif (xml.attributes.length > 0) {obj["@attributes"] = {};for (var j = 0; j < xml.attributes.length; j++) {var attribute = xml.attributes.item;obj["@attributes"][attribute.nodeName] = attribute.nodeValue;}}} else if  { // textobj = xml.nodeValue;}// do childrenif  {for (var i = 0; i < xml.childNodes.length; i++) {var item = xml.childNodes.item;var nodeName = item.nodeName;if (typeof  == "undefined") {obj[nodeName] = xmlToJson;} else {if (typeof  == "undefined") {var old = obj[nodeName];obj[nodeName] = [];obj[nodeName].push;}obj[nodeName].push;}}}return obj;};

在线json压缩/转义工具:

之后我做了些改动,将它解析成如下格式后,满足了“文本混合标签”可正确还原的情况。

SAMPLE SCRIPT:

同样,在一个标签内,它的子标签出现了大于一次,如果需要记录数据的路径,应该使用数组来保存这个结构。正确的代码应该是:

这里来分享一个关于JavaScript实现XML与JSON互转例子,这里面介绍了国外的三款xml转json的例子,希望这些例子能给你带来帮助。

jkl.parsexml

x2js :

The major change I needed to implement was using attributes.item instead
of the attributes[j] that most of the scripts I found used. With this
function, XML that looks like:

在线JSON代码检验、检验、美化、格式化工具:

 第一节  标题  第二节
{"p":"章节段落"}}

XML在线压缩/格式化工具:

jsonxml :

x2js不会将下面的XML正确还原。

本文实例讲述了JavaScript实现的XML与JSON互转功能。分享给大家供大家参考,具体如下:

{"p":[{"strong":"章节"},"段",{"em":"落"}]}
{ "@attributes": { AID: "=", HOME: 0, URL: "davidwalsh.name/", VER: "0.9", }, SD = [ { "@attributes": { FLAGS: "", HOST: "davidwalsh.name", TITLE: A }, LINKSIN: { "@attributes": { NUM: 1102 } }, SPEED: { "@attributes": { PCT: 51, TEXT: 1421 } }, TITLE: { "@attributes": { TEXT: "David Walsh Blog :: PHP, MySQL, CSS, Javascript, MooTools, and Everything Else", } }, }, { POPULARITY: { "@attributes": { TEXT: 7131, URL: "davidwalsh.name/" } }, RANK: { "@attributes": { DELTA: "-1648" } }, REACH: { "@attributes": { RANK = 5952 } } } ]}
 文章标题  章节标题 

{"article": {"header": {"#text": "文章标题","@id": "h1"},"section": {"@id": "s1","header": "章节标题","p": "章节段落"}}}
//XML形式 章节段落 

OUTPUT JSON:

&lt;!-- var url = "zip-e.xml"; var xml = new JKL.ParseXML; var data = xml.parse(); document.write( data["items"]["item"]["us_state"] ); document.write( data.items.item.us_state );// --&gt;
  10036 NY New York Broadway 

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图