我有一些我在jQuery中解析的XML。
<payload>
<value key="VehicleMake">
<value key="description">Aeon</value>
<value key="code">18</value>
</value>
<value key="VehicleMake">
<value key="description">Alfa Romeo</value>
<value key="code">120</value>
</value>
</payload>
在IE以外的所有浏览器(特别是IE8)中,以下工作:
$.ajax({
type : "GET",
async : false,
url : "/services/vehiclemake",
success :
function(xmlResponse) {
var data = $("payload", xmlResponse).children("value").map(function() {
//IE8 fails on the next line
var code = $(this).children("value [key='code']").text();
var desc = $(this).children("value [key='description']").text();
return {
value : desc,
vehicleCode : code,
label : desc
};
}).get();
}
});
在IE8中,对“代码”的赋值失败说:“TypeError:Object不支持此属性或方法”。
如果我使用这种方法,那就没关系了:
$.ajax({
type : "GET",
async : false,
url : "/services/vehiclemake",
success :
function(xmlResponse) {
var data = $("payload", xmlResponse).children("value").map(function() {
var code;
var desc;
var elements = $(this).children();
for (i = 0; i < elements.length; i++) {
if(elements[i].attributes.getNamedItem("key").value == 'code') {
code = elements[i].text;
}
if(elements[i].attributes.getNamedItem("key").value == 'description') {
desc = elements[i].text;
}
}
var desc = $(this).children("value [key='description']").text();
return {
value : desc,
vehicleCode : code,
label : desc
};
}).get();
有谁能告诉我为什么标准的jQuery属性选择器在IE8中不起作用?使用正确的mime类型返回XML。
感谢。
答案 0 :(得分:2)
我认为你不想要一个空间:
.children("value[key='code']")
可能无法解决,但我认为无论如何都需要修复。