이번에는 JS로 XML과 JSON을 변환하는 방법을 알려드리겠습니다. JS로 XML과 JSON을 변환할 때 주의사항은 무엇인가요?
개발 중에 가끔 XML과 JSON이 서로 변환되어 JS에서 사용해야 합니다. 인터넷에서 많이 검색했지만 유용한 것은 모두 팔이나 다리가 없거나 단어가 무엇인지 표현하지 못했습니다. 너무 불합리하고 결정적이어서 직접 구현해 보세요.
JSON과 XML의 차이점 비교
1. 정의 소개
(1).XML 정의
XML(Extensible Markup Language)은 전자 문서에 구조 A를 제공하는 데 사용됩니다. 데이터를 표시하고 데이터 유형을 정의하는 데 사용할 수 있는 고유한 마크업 언어입니다. 사용자가 자신의 마크업 언어를 정의할 수 있는 소스 언어입니다. XML은 DTD(문서 유형 정의) 문서 유형 정의를 사용하여 데이터를 구성합니다. 형식은 크로스 플랫폼 및 언어로 통합되어 있으며 오랫동안 업계에서 인정받는 표준이 되었습니다.
XML은 SGML(Standard Generalized Markup Language)의 하위 집합이며 웹 전송에 매우 적합합니다. XML은 응용 프로그램이나 공급업체에 관계없이 구조화된 데이터를 설명하고 교환하기 위한 통합된 방법을 제공합니다.
(2).JSON 정의
JSON(JavaScript Object Notation)은 가독성이 좋고 빠르게 작성하기 쉬운 경량 데이터 교환 형식입니다. 서로 다른 플랫폼 간의 데이터 교환이 가능합니다. JSON은 호환성이 높고 완전히 언어 독립적인 텍스트 형식을 채택하며 C 언어 습관(C, C++, C#, Java, JavaScript, Perl, Python 등 포함)과 유사한 시스템 동작을 갖습니다. 이러한 속성은 JSON을 이상적인 데이터 교환 언어로 만듭니다.
JSON은 표준 ECMA-262 3판(1999년 12월)의 하위 집합인 JavaScript 프로그래밍 언어를 기반으로 합니다.
2. XML과 JSON의 장점과 단점
(1). XML의 장점과 단점
f35d6e602fd7d0f0edfa6f7d103c1b57.
2cc198a1d5eb0d3eb508d858c9f5cbdb XML의 단점
B. 서버와 클라이언트 모두 XML을 구문 분석하는 데 많은 코드를 소비해야 합니다. 서버와 클라이언트 코드를 변경하는 것은 매우 복잡하고 유지 관리가 어렵습니다.
C. 클라이언트 측에서 서로 다른 브라우저 간에 XML을 구문 분석하는 방식이 일관성이 없으며 많은 코드를 반복적으로 작성해야 합니다. 서버 측과 클라이언트 측에서 XML을 구문 분석하는 데 더 많은 리소스와 시간이 소요됩니다.
(2). JSON의 장점과 단점
<1>. JSON의 장점: A. 데이터 형식이 비교적 간단하고 읽기 및 쓰기가 쉽고 형식이 압축되어 대역폭을 거의 차지하지 않습니다. ;
B. 간편한 구문 분석, 클라이언트 측 JavaScript는 eval()을 통해 JSON 데이터를 간단히 읽을 수 있습니다.
XML 및 JSON을 Javascript로 변환
호출 예제를 먼저 살펴보세요:
<viewport id="menuPane" layout="border"> <panel region="center" border="0" layout="border"> <tbar> <toolbar text="XXXX"> <menu> <text text="11"> </text> <text text="22"> </text> <text text="33"> </text> </menu> </toolbar> <toolbar text="XXXX"> <menu> <text text="44"> </text> <text text="55"> </text> <menu> <text text="6 6"> </text> </menu> <text text="77"> </text> </menu> </toolbar> </tbar> </panel> </viewport> var xmlParser = new XmlToJson(); var json = xmlParser.parse(xml); console.log( JSON.stringify(json) ); var jsonParser = new JsonToXml(); var xml = jsonParser.parse(json); console.log( xml );
XML에서 JSON으로 변환:
function XmlToJson() { } XmlToJson.prototype.setXml = function(xml) { if(xml && typeof xml == "string") { this.xml = document.createElement("p"); this.xml.innerHTML = xml; this.xml = this.xml. getElementsByTagName ("*")[0]; } else if(typeof xml == "object"){ this.xml = xml; } }; XmlToJson.prototype.getXml = function() { return this.xml; }; XmlToJson.prototype.parse = function(xml) { this.setXml(xml); return this.convert(this.xml); }; XmlToJson.prototype.convert = function(xml) { if (xml.nodeType != 1) { return null; } var obj = {}; obj.xtype = xml.nodeName.toLowerCase(); var nodeValue = (xml.textContent || "").replace(/(\r|\n)/g, "").replace(/^\s+|\s+$/g, ""); if(nodeValue && xml.childNodes.length == 1) { obj.text = nodeValue; } if (xml.attributes.length > 0) { for (var j = 0; j < xml.attributes.length; j++) { var attribute = xml.attributes.item(j); obj[attribute.nodeName] = attribute.nodeValue; } } if (xml.childNodes.length > 0) { var items = []; for(var i = 0; i < xml.childNodes.length; i++) { var node = xml.childNodes.item(i); var item = this.convert(node); if(item) { items.push(item); } } if(items.length > 0) { obj.items = items; } } return obj; };JSON에서 XML로 변환:
function JsonToXml() { this.result = []; } JsonToXml.prototype.spacialChars = ["&","<",">","\"","'"]; JsonToXml.prototype.validChars = ["&","<",">",""","'"]; JsonToXml.prototype.toString = function(){ return this.result.join(""); }; JsonToXml.prototype.replaceSpecialChar = function(s){ for(var i=0;i<this.spacialChars.length;i++){ s=s.replace(new RegExp(this.spacialChars[i],"g"),this.validChars[i]); } return s; }; JsonToXml.prototype.appendText = function(s){ s = this.replaceSpecialChar(s); this.result.push(s); }; JsonToXml.prototype.appendAttr = function(key, value){ this.result.push(" "+ key +"=\""+ value +"\""); }; JsonToXml.prototype.appendFlagBeginS = function(s){ this.result.push("<"+s); }; JsonToXml.prototype.appendFlagBeginE = function(){ this.result.push(">"); }; JsonToXml.prototype.appendFlagEnd = function(s){ this.result.push("</"+s+">"); }; JsonToXml.prototype.parse = function(json){ this.convert(json); return this.toString(); }; JsonToXml.prototype.convert = function(obj) { var nodeName = obj.xtype || "item"; this.appendFlagBeginS(nodeName); var arrayMap = {}; for(var key in obj) { var item = obj[key]; if(key == "xtype") { continue; } if(item.constructor == String) { this.appendAttr(key, item); } if(item.constructor == Array) { arrayMap[key] = item; } } this.appendFlagBeginE(); for(var key in arrayMap) { var items = arrayMap[key]; for(var i=0;i<items.length;i++) { this.convert(items[i]); } } this.appendFlagEnd(nodeName); };이 글을 읽으셨을 것 같습니다. 사례 방법을 익힌 후에는 PHP 중국어 웹사이트의 다른 관련 기사를 주목하여 더 흥미로운 내용을 확인하세요! 추천 자료:
Json을 구문 분석하는 방법은 무엇입니까
위 내용은 JS 간에 XML과 JSON을 변환하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!