I need help for writing cross Browser for writing code for my JavaScript code. While Executing my JavaScript on Internet explorer 8 i get error for object.key. So i need some help to fix my code so that i can run on Internet explorer 8 properly.And secondly expandable and collapsable is not working on sortObject function. Please update my fiddle and provide me a link. Following is the live fiddle link:
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;
},
sortedObject = function (obj) {
var ul = document.createElement("ul"),
li,span, sorted = [],
i = 0;
for (var prop in obj) {
sorted.push(prop);
}
sorted.sort();
for (; i < sorted.length; i++) {
li = document.createElement("li");
span = document.createElement("span");
span.innerHTML = sorted[i];
span.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();
}
li.appendChild(span);
if (typeof obj[sorted[i]] == "object" && Object.keys(obj[sorted[i]]).length) {
console.log(Object.keys(obj[sorted[i]]).length + " " + Object.keys(obj[sorted[i]]));
li.appendChild(sortedObject(obj[sorted[i]]));
} 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));
}
Thank you