2016-12-05 13 views
1

xml response to jsonangularjsに変換する必要があります。私はxml形式で応答を提供するRest APIを使用していますが、$ http.get()を介して取得する際にはangularjsにjson応答が必要です。angularjsを使用してdbからレコードを取得した後にxmlをjsonに変換します

以下は、angularjsにrest APIを使用している方法です。

<script> 
var app = angular.module('myApp', []); 
app.controller('myCtrl', function($scope,$http) { 

$http({ 
method: 'GET', 
url: "https://some-url?fieldList=field1,field2" 
}).then(function(response) { 
     $scope.obj=response.data.records;},function(response){});} 
}); 
</scripts> 

xml応答をjsonに変換し、それを変数$ scope.objの入力として提供する方法は?ここで

答えて

0

は、私はこのページにhttps://davidwalsh.name/convert-xml-json

var xhttp = new XMLHttpRequest(); 
xhttp.onreadystatechange = function() { 
if (this.readyState == 4 && this.status == 200) { 
    myFunction(this); 
} 
}; 
xhttp.open("GET", "your.xml", true); 
xhttp.send(); 

function myFunction(xml) { 
var xmlDoc = xml.responseXML; 
document.getElementById("demo").innerHTML = 
xmlToJson(xmlDoc); 
} 
function xmlToJson(xml) { 

// Create the return object 
var obj = {}; 

if (xml.nodeType == 1) { // element 
    // do attributes 
    if (xml.attributes.length > 0) { 
    obj["@attributes"] = {}; 
     for (var j = 0; j < xml.attributes.length; j++) { 
      var attribute = xml.attributes.item(j); 
      obj["@attributes"][attribute.nodeName] = attribute.nodeValue; 
     } 
    } 
} else if (xml.nodeType == 3) { // text 
    obj = xml.nodeValue; 
} 

// do children 
if (xml.hasChildNodes()) { 
    for(var i = 0; i < xml.childNodes.length; i++) { 
     var item = xml.childNodes.item(i); 
     var nodeName = item.nodeName; 
     if (typeof(obj[nodeName]) == "undefined") { 
      obj[nodeName] = xmlToJson(item); 
     } else { 
      if (typeof(obj[nodeName].push) == "undefined") { 
       var old = obj[nodeName]; 
       obj[nodeName] = []; 
       obj[nodeName].push(old); 
      } 
      obj[nodeName].push(xmlToJson(item)); 
     } 
    } 
} 
return obj; 
}; 
を与えられた機能を使用し、あなたがこれを達成することができますどのように ある
関連する問題