我有一个像这样的XML文件:
<content>
<box>
<var1>A1</var1>
<var2>B1</var2>
<var3>C1</var3>
<var4>D1</var4>
</box>
<box>
<var1>A2</var1>
<var2>B2</var2>
<var3>C2</var3>
<var4>D2</var4>
</box>
<box>
<var1>A3</var1>
<var2>B3</var2>
<var3>C3</var3>
<var4>D3</var4>
</box>
</content>
它有500个box
个元素,我需要将它们解析为JavaScript对象。我正在使用这个代码工作正常,但我是一个新手,也许我错过了一些东西,如果有更好/更快的方法,我想得到建议:
var app = {
//...
box: [],
init: function (file) {
var that = this;
$.ajax({
type: "GET",
url: file,
dataType: "xml",
success: function (xml) {
$("box", xml).each(function (i) {
var e = $(this);
that.box[i] = new Box(i, {
var1: e.children("var1").text(),
var2: e.children("var2").text(),
var3: e.children("var3").text(),
var4: e.children("var4").text()
});
});
}
});
},
//...
};
提前致谢。
答案 0 :(得分:3)
我有一个我不得不使用的XML源代码..我在客户端转换为JSON然后加载它...更容易..
Tracker.loadCasesFromServer = function () {
$.ajax({
type: 'GET',
url: '/WAITING.CASES.XML',
dataType: 'xml',
success: function (data) {
Tracker.cases = jQuery.parseJSON(xml2json(data, ""));
Tracker.loadCasesToMap();
},
data: {},
async: true
});
};
使用可在此处找到的XML2JSON转换器:http://www.thomasfrank.se/xml_to_json.html
邓肯
答案 1 :(得分:2)
尽可能使用JSON。这样浏览器就会为您进行解析,您不必进行任何后期处理。
来自服务器的JSON
{"content":
{"box": [
{"var1": "A1",
"var2": "B1",
"var3": "C1",
"var4": "D1"},
{"var1": "A2",
"var2": "B2",
"var3": "C2",
"var4": "D2"},
{"var1": "A3",
"var2": "B3",
"var3": "C3",
"var4": "D3"}]}}
客户端JavaScript
var app = {
//...
box: [],
init: function (file) {
var that = this;
$.ajax({
type: "GET",
url: file,
dataType: "json",
success: function(result) {
that.box = $.map(result.content.box, function(box, i) {
return new Box(i, box);
});
}
});
},
//...
};
答案 2 :(得分:0)
您可以使用浏览器原生XML支持,我想这会很快。然而,这在浏览器中是不同的,例如(Firefox:DOMParser,IE:XMLDOM ..)。
因此,您可以使用类似https://sites.google.com/a/van-steenbeek.net/archive/explorer_domparser_parsefromstring
之类的内容,而不是仅仅继续并手动处理所有浏览器