Blame view

node_modules/uglify-js/tools/props.html 1.6 KB
aaac7fed   liuqimichale   add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
  <html>
    <head>
    </head>
    <body>
      <script>(function(){
        var props = {};
  
        function addObject(obj) {
          if (obj == null) return;
          try {
            Object.getOwnPropertyNames(obj).forEach(add);
          } catch(ex) {}
          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]);
        });
  
        try {
          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"));
        } catch(ex) {}
  
        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"); -->
        ta.value = JSON.stringify({
          vars: [],
          props: Object.keys(props).sort(cmp)
        }, null, 2);
        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>