The source file foo/bar.mdwn
or foo/bar.html
generates the
page foo/bar/index.html
, but the links to the page appear
as "foo/bar/
". This is fine (and recommended) for pages
served by an http server, but it doesn't work when browsing
the pages directly using file:
URL. The latter might be
desirable when testing pages before upload, or if you want to
read pages when off-line without access to a web server.
Here is a JavaScript "onload
" script which fixes the URLs
if the local.protocol
isn't http
or https
:
function fixLinks() {
var scheme = location.protocol;
if (scheme=="http:" || scheme=="https:") return;
var links = document.getElementsByTagName("a");
for (var i = links.length; --i >= 0; ) {
var link = links[i];
var href = link.href;
var hlen = href.length;
if (hlen > 0 && link.protocol==scheme && href.charAt(hlen-1) == "/")
links[i].href = href + "index.html";
}
}
This can be placed in page.tmpl
:
<html>
<head>
<script language="JavaScript">
function fixLinks() {
...
}
</script>
</head>
<body onload="javascript:fixLinks();">
...
</html>
This script has not been extensively tested.
A version that handles anchors:
function fixLinks() {
var scheme = location.protocol;
if (scheme != "file:") return;
var links = document.getElementsByTagName("a");
for (var i = links.length; --i >= 0; ) {
var link = links[i];
var href = link.href;
var anchor = "";
var anchorIndex = href.indexOf("#");
if (anchorIndex != -1) {
anchor = href.substring(anchorIndex);
href = href.substring(0, anchorIndex);
};
var hlen = href.length;
if (hlen > 0 && link.protocol==scheme && href.charAt(hlen-1) == "/")
links[i].href = href + "index.html" + anchor;
}
}