您好,登錄后才能下訂單哦!
本文實例講述了nodejs實現(xiàn)解析xml字符串為對象的方法。分享給大家供大家參考,具體如下:
var xmlreader = require("xmlreader"); var fs = require("fs"); var xml_string = '<response id="1" shop="aldi">' + 'This is some other content' + '<who name="james">James May</who>' + '<who name="sam">' + 'Sam Decrock' + '<location>Belgium</location>' + '</who>' + '<who name="jack">Jack Johnsen</who>' + '<games age="6">' + '<game>Some great game</game>' + '<game>Some other great game</game>' + '</games>' + '<note>These are some notes</note>' + '</response>'; xmlreader.read(xml_string, function(errors, response){ if(null !== errors ){ console.log(errors) return; } console.log( response.response ); console.log( response.response.text() ); });
沒啥新奇的,看看輸出吧
第一句輸出結(jié)果為:
{ attributes : [Function], parent : [Function], count : [Function], at : [Function], each : [Function], text : [Function], who : { array : [[Object], [Object], [Object]], count : [Function], at : [Function], each : [Function] }, games : { attributes : [Function], parent : [Function], count : [Function], at : [Function], each : [Function], game : { array : [Object], count : [Function], at : [Function], each : [Function] } }, note : { attributes : [Function], parent : [Function], count : [Function], at : [Function], each : [Function], text : [Function] } }
第二句輸出:
This is some other content
根據(jù)輸出我們就可以猜這東西是怎么回事兒了。
1、xmlreader
將xml轉(zhuǎn)換為JSON對象(這樣表述不準確,但是大家知道怎么一回事兒)。
2、轉(zhuǎn)換成的JSON對象的嵌套結(jié)構(gòu)與原xml標簽嵌套結(jié)構(gòu)相同。
3、視xml中同一級別出現(xiàn)某標簽次數(shù)不同(一次和多次)生出不同的對應(yīng)對象,如上的node為一次,who為三次。
4、提供了一下函數(shù)供操作屬性或者遍歷等等。
各方法含義:
1、attributes:獲取所有屬性。
2、parent:獲取父節(jié)點。
3、count:獲取數(shù)目。
4、at:獲取下標為指定值的節(jié)點。
5、each:遍歷,參數(shù)為一個函數(shù)。
6、text:獲取節(jié)點內(nèi)的文本,僅當前節(jié)點的文本,不包含子節(jié)點的文本。
PS:這里再為大家提供幾款關(guān)于xml操作的在線工具供大家參考使用:
在線XML/JSON互相轉(zhuǎn)換工具:
http://tools.jb51.net/code/xmljson
在線格式化XML/在線壓縮XML:
http://tools.jb51.net/code/xmlformat
XML在線壓縮/格式化工具:
http://tools.jb51.net/code/xml_format_compress
XML代碼在線格式化美化工具:
http://tools.jb51.net/code/xmlcodeformat
希望本文所述對大家nodejs程序設(shè)計有所幫助。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。