io sono sempre familiarità con l'API HTML5 Storia, ma sto usando history.js per estendere la compatibilità,History API html5, come sapere quando l'utente ha fatto clic sui pulsanti del browser successivo/posteriore?
ho una domanda ed è che, come posso sapere a:
History.Adapter.bind(window,'statechange',function(){ // Note: We are using statechange instead of popstate
var State = History.getState(); // Note: We are using History.getState() instead of event.state
/* Condition here to know if this change is a back or next button, and wich one?? */
});
Questo è il mio codice "tutto" ...
var the = this;
var History = window.History;
if (!History.enabled) {
return false;
}
/* Store the initial content*/
History.replaceState({
content: $('#main').html()
}, document.title, document.location.href);
/* Bind to StateChange Event */
History.Adapter.bind(window,'statechange',function(){ // Note: We are using statechange instead of popstate
var State = History.getState(); // Note: We are using History.getState() instead of event.state
//console.log(State);
//History.log(State.data, State.title, State.url);
console.log(history.length);
});
/* triggers */
$(document).on('click','a',function(e){
e.preventDefault();
var href = $(this).attr('href');
var title = $(this).text();
if(href == '#')
href = title;
$.get('portfolio.html',function(data, response){
var html = $(data).find('#main-content').html();
//console.log(html);
$('#ajax-load').html(html);
History.pushState({ content: html}, title, href);
$('#ajax-load').css({ position:'absolute',
right: -$(window).width(),
top: the.header.height(),
width: $(window).width(),
zIndex:999
}).animate({ right: 0 },300,function(){
console.log($('#main-content').length);
console.log($('#ajax-load').length);
$('#main-content').html(html);
$('#ajax-load').html('');
});
});
});
Perché l'unica ragione per cui dovrei in realtà controlla per la storia è per il pulsante NEXT/indietro, giusto? altrimenti le regole di ancoraggio href
operativa -Editazione-
fondamentalmente ho bisogno la condizione da qui
History.Adapter.bind(window,'statechange',function(){
var State = History.getState();
var condition = false;
if(condition){
console.log('You clicked the next/back button');
}
});
Grazie in anticipo
Avete verificato questo domanda http://stackoverflow.com/questions/6359327/detect-back-button-click-in-browser –
o questo: http://stackoverflow.com/questions/16548141/is-there-a-way-to- tell-what-direction-the-state-is-going-with-history-js/16630032 # 16630032 ?? –