我的Javascript需要一些帮助,问题是我的JavaScript代码在Internet Explorer 8以及Internet Explorer 7上运行不正常,它给出的错误是Internet Explorer 8/7上不支持currentTarget。所以我需要一些帮助来解决这个问题,并在Internet Explorer 8/7上工作。
var dataSource = ({
"Pen": ({
"Cello": ({
"C2": ({}),
"C1": ({})
}),
"Parker": ({
"P2": ({}),
"P1": ({})
})
})
});
var traverseObject = function (obj) {
var ul = document.createElement("ul"),
li;
for (var prop in obj) {
li = document.createElement("li");
li.appendChild(document.createTextNode(prop));
li.onclick = function(e) {
var classNames = e.currentTarget.className;
if (classNames.indexOf("hidden") == -1) {
e.currentTarget.className += "hidden";
} else {
e.currentTarget.className = e.currentTarget.className.replace("hidden", "");
}
e.stopPropagation();
}
if (typeof obj[prop] == "object" && Object.keys(obj[prop]).length) {
console.log(Object.keys(obj[prop]).length + " " + Object.keys(obj[prop]));
li.appendChild(traverseObject(obj[prop]));
} else {
li.className += "leaf";
}
ul.appendChild(li);
console.log(ul);
}
return ul;
};
window.onload = function () {
document.getElementById("dvList1").appendChild(traverseObject(dataSource));
document.getElementById("dvList2").appendChild(sortedObject(dataSource));
}
谢谢
答案 0 :(得分:1)
您只需在事件处理程序中使用this
keyword而不是e.currentTarget
。
答案 1 :(得分:0)
我建议你,不要修复兼容的问题,而是要找到一些已经解决了兼容问题的工具。 在这里,我建议你使用JQuery来重写脚本。
li.onclick -> $(li).click(function(event){/*process code*/})
希望这有帮助