/[suikacvs]/webroot/www/url/urlresolution.en.html
Suika

Contents of /webroot/www/url/urlresolution.en.html

Parent Directory Parent Directory | Revision Log Revision Log


Revision 1.1 - (hide annotations) (download) (as text)
Sat Jul 5 14:00:29 2008 UTC (16 years, 4 months ago) by wakaba
Branch: MAIN
File MIME type: text/html
New

1 wakaba 1.1 <!DOCTYPE HTML>
2     <html lang=en>
3     <head>
4     <title>Live URL Resolution Viewer</title>
5     <link rel=author href="http://suika.fam.cx/~wakaba/who?" title=Wakaba lang=ja>
6     <style>
7     h1 {
8     font-size: 100%;
9     }
10     textarea {
11     width: 90%;
12     height: 3em;
13     }
14     iframe {
15     visibility: hidden;
16     width: 0;
17     height: 0;
18     }
19     var {
20     color: orange;
21     }
22     </style>
23     <script>
24     document.createElement ('output');
25    
26     var updateTimer = 0;
27     function update () {
28     if (updateTimer) {
29     clearTimeout (updateTimer);
30     }
31     updateTimer = setTimeout (realUpdate, 100);
32     } // update
33    
34     function htescape (s) {
35     return s.replace (/&/g, '&amp;')
36     .replace (/</g, '&lt;')
37     .replace (/>/g, '&gt;')
38     .replace (/"/g, '&quot;');
39     } // htescape
40    
41     function htescape2 (s) {
42     return s.replace (/&/g, '&amp;')
43     .replace (/</g, '&lt;')
44     .replace (/>/g, '&gt;')
45     .replace (/"/g, '&quot;')
46     .replace (/[\u0000-\u0020\u007F-\u00A0]/g, function (t) {
47     return '<var>&amp;#x' + t.charCodeAt (0).toString (16).toUpperCase () + ';</var>';
48     });
49     } // htescape2
50    
51     function realUpdate () {
52     var baseURL = document.getElementById ('base-url').value;
53     var resolvedURL = document.getElementById ('resolved-url').value;
54    
55     var pl = document.getElementById ('permalink');
56     pl.href = location.pathname + '?' + encodeURIComponent (baseURL) + ';' +
57     encodeURIComponent (resolvedURL);
58    
59     var iframe = document.getElementsByTagName ('iframe')[0];
60     var doc = iframe.contentWindow.document;
61     doc.open ();
62     doc.write ('<!DOCTYPE HTML>');
63     doc.write ('<base href="' + htescape (baseURL) + '">');
64     doc.write ('<a href="' + htescape (resolvedURL) + '">xx</a>');
65     doc.close ();
66    
67     var resultURL = doc.getElementsByTagName ('a')[0].href;
68     var output = document.getElementsByTagName ('output')[0];
69     output.innerHTML = '';
70     if (typeof (resultURL) == 'undefined') {
71     output.innerHTML = '(undefined)';
72     } else if (resultURL === null) {
73     output.innerHTML = '(null)';
74     } else if (resultURL === '') {
75     output.innerHTML = '(empty string - URL resolution failed?)';
76     } else {
77     output.innerHTML = '<code>' + htescape2 ('' + resultURL) +
78     '</code> of type <code>' + htescape (typeof (resultURL)) + '</code>';
79     }
80     } // realUpdate
81    
82     window.onload = function () {
83     if (location.search) {
84     var q = location.search.substring (1).split (/;/);
85     if (q[0] != null) {
86     document.getElementById ('base-url').value = decodeURIComponent (q[0]);
87     }
88     if (q[1] != null) {
89     document.getElementById ('resolved-url').value = decodeURIComponent (q[1]);
90     }
91     }
92    
93     update ();
94     }; // window.onload
95     </script>
96     </head>
97     <body>
98     <h1>Live URL Resolution Viewer
99     (<a rel=bookmark id=permalink href>Permalink</a>)</h1>
100    
101     <dl>
102     <dt><label for=resolved-url>Resolved URL</label>:
103     <dd><textarea id=resolved-url oninput="update()" onkeypress="update()"></textarea>
104     <dt><label for=base-url>Base URL</label>:
105     <dd><textarea id=base-url oninput="update()" onkeypress="update()"></textarea>
106     </dl>
107     <hr>
108     <dl>
109     <dt>Result (Using <code>HTMLAnchorElement.href</code>):
110     <dd><output></output>
111     </dl>
112    
113     <iframe></iframe>
114    
115     </body>
116     </html>

admin@suikawiki.org
ViewVC Help
Powered by ViewVC 1.1.24