mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
87 lines
3.6 KiB
HTML
87 lines
3.6 KiB
HTML
<!DOCTYPE HTML>
|
|
<html>
|
|
<head>
|
|
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
|
|
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
|
|
<title>
|
|
History.js
|
|
</title>
|
|
</head>
|
|
<body style="padding-bottom:40px">
|
|
<!-- Scripts -->
|
|
<script>if ( typeof window.JSON === 'undefined' ) { document.write('<script src="../scripts/uncompressed/json2.js"><\/script>'); }</script>
|
|
<script src="../vendor/jquery.js"></script>
|
|
<script src="../scripts/bundled/html4+html5/jquery.history.js"></script>
|
|
|
|
<!-- HTML -->
|
|
<div id="wrap">
|
|
<!-- Intro -->
|
|
<h1><a href="https://github.com/balupton/History.js">History.js</a> by <a href="http://balupton.com">Benjamin Lupton</a></h1>
|
|
<p>History.js gracefully supports the <a href="https://developer.mozilla.org/en/DOM/Manipulating_the_browser_history">HTML5 History/State APIs</a> (pushState, replaceState, onPopState) in all browsers. Including continued support for data, titles, replaceState. Supports <a href="http://jquery.com/">jQuery</a>, <a href="http://mootools.net">MooTools</a> and <a href="http://prototypejs.org">Prototype</a>. For HTML5 browsers this means that you can modify the URL directly, without needing to use hashes anymore. For HTML4 browsers it will revert back to using the old onhashchange functionality.</p>
|
|
|
|
<!-- Textarea for Logging -->
|
|
<textarea id="log" style="width:100%;height:400px"></textarea>
|
|
|
|
<!-- Note -->
|
|
<p>Click through the buttons in order and you'll get the results demonstrated in the <a href="../README.md">README.md</a> file.</p>
|
|
|
|
<!-- Buttons -->
|
|
<ul id="buttons">
|
|
</ul>
|
|
|
|
<!-- Our Script -->
|
|
<script>
|
|
(function(window,undefined){
|
|
|
|
// Check Location
|
|
if ( document.location.protocol === 'file:' ) {
|
|
alert('The HTML5 History API (and thus History.js) do not work on files, please upload it to a server.');
|
|
}
|
|
|
|
// Establish Variables
|
|
var
|
|
History = window.History, // Note: We are using a capital H instead of a lower h
|
|
State = History.getState(),
|
|
$log = $('#log');
|
|
|
|
// Log Initial State
|
|
History.log('initial:', State.data, State.title, State.url);
|
|
|
|
// Bind to State Change
|
|
History.Adapter.bind(window,'statechange',function(){ // Note: We are using statechange instead of popstate
|
|
// Log the State
|
|
var State = History.getState(); // Note: We are using History.getState() instead of event.state
|
|
History.log('statechange:', State.data, State.title, State.url);
|
|
});
|
|
|
|
// Prepare Buttons
|
|
var
|
|
buttons = document.getElementById('buttons'),
|
|
scripts = [
|
|
'History.pushState({state:1,rand:Math.random()}, "State 1", "?state=1"); // logs {state:1,rand:"some random value"}, "State 1", "?state=1"',
|
|
'History.pushState({state:2,rand:Math.random()}, "State 2", "?state=2"); // logs {state:2,rand:"some random value"}, "State 2", "?state=2"',
|
|
'History.replaceState({state:3,rand:Math.random()}, "State 3", "?state=3"); // logs {state:3,rand:"some random value"}, "State 3", "?state=3"',
|
|
'History.pushState(null, null, "?state=4"); // logs {}, "", "?state=4"',
|
|
'History.back(); // logs {state:3}, "State 3", "?state=3"',
|
|
'History.back(); // logs {state:1}, "State 1", "?state=1"',
|
|
'History.back(); // logs {}, "The page you started at", "?"',
|
|
'History.go(2); // logs {state:3}, "State 3", "?state=3"'
|
|
],
|
|
buttonsHTML = ''
|
|
;
|
|
|
|
// Add Buttons
|
|
for ( var i=0,n=scripts.length; i<n; ++i ) {
|
|
var _script = scripts[i];
|
|
buttonsHTML +=
|
|
'<li><button onclick=\'javascript:'+_script+'\'>'+_script+'</button></li>';
|
|
}
|
|
buttons.innerHTML = buttonsHTML;
|
|
|
|
})(window);
|
|
</script>
|
|
</div>
|
|
|
|
</body>
|
|
</html>
|