ja poznania API HTML5 historii, ale używam history.js rozszerzyć kompatybilność,Historia API html5, jak się dowiedzieć, kiedy użytkownik kliknął przycisk następnej/poprzedniej przeglądarki?
Mam jedno pytanie i to, że jak mogę wiedzieć:
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?? */
});
To jest mój "cały" kod ...
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('');
});
});
});
Bo jedynym powodem, dla którego powinienem sprawdzić historię jest przycisk NEXT/BACK, prawda? w przeciwnym razie zasady kotwica href
-EDIT-
zasadzie muszę warunek stąd
History.Adapter.bind(window,'statechange',function(){
var State = History.getState();
var condition = false;
if(condition){
console.log('You clicked the next/back button');
}
});
Dzięki z góry
Czy to wyrejestrowany pytanie http://stackoverflow.com/questions/6359327/detect-back-button-click-in-browser –
lub to: http://stackoverflow.com/questions/16548141/is-there-a-way-to- tell-what-direction-the-state-is-going-with-history-js/16630032 # 16630032 ?? –