Add tool to list DOM properties/methods

This commit is contained in:
Mihai Bazon
2015-03-17 11:46:04 +02:00
parent 80cfd063e2
commit f5eeed7665

53
tools/props.html Normal file
View File

@@ -0,0 +1,53 @@
<html>
<head>
</head>
<body>
<script>(function(){
var props = Object.create(null);
function addObject(obj) {
if (obj == null) return;
Object.getOwnPropertyNames(obj).forEach(add);
if (obj.prototype) {
Object.getOwnPropertyNames(obj.prototype).forEach(add);
}
if (typeof obj == "function") {
try {
Object.getOwnPropertyNames(new obj).forEach(add);
} catch(ex) {}
}
}
function add(name) {
props[name] = true;
}
Object.getOwnPropertyNames(window).forEach(function(thing){
addObject(window[thing]);
});
addObject(new Event("click"));
addObject(new Event("contextmenu"));
addObject(new Event("mouseup"));
addObject(new Event("mousedown"));
addObject(new Event("keydown"));
addObject(new Event("keypress"));
addObject(new Event("keyup"));
var ta = document.createElement("textarea");
ta.style.width = "100%";
ta.style.height = "20em";
ta.style.boxSizing = "border-box";
ta.value = Object.keys(props).sort(cmp).map(function(name){
return JSON.stringify(name);
}).join(",\n");
document.body.appendChild(ta);
function cmp(a, b) {
a = a.toLowerCase();
b = b.toLowerCase();
return a < b ? -1 : a > b ? 1 : 0;
}
})();</script>
</body>
</html>