15

我正在使用 history.JS (latest) 和 Jquery (latest) 来加载和替换网站的一部分,这一切都在工作,目前我只是想让它在现代浏览器中工作,所以我没有摆弄随着哈希的变化。

一切似乎都正常,但是当我单击浏览器(最新的 FF 和 Chrome)上的后退按钮时,页面并没有改变(尽管 url 和标题确实改变了)。我有一个谷歌和看这里,但我看不到发生了什么。

查看堆栈溢出时,我发现了这个页面:Restoring content when click back button with History.js,这似乎在问一个类似的问题。我已经将#left_col(被替换的div)的加载内容添加到状态数据中,但我不确定从那里去哪里,我知道当状态改变时我需要重新加载该数据,但我不知道怎么做。

var History = window.History; 
var origTitle = document.title;
if ( !History.enabled ) {
    return false;
}
    
History.Adapter.bind(window,'statechange',function(){ 
    var State = History.getState();     
    History.log(State.data, State.title, State.url);
});

$('.ajaxload').live("click", function() {
    History.pushState({state:1,leftcol:$('#left_col').html()}, origTitle, $(this).attr("href"));
    $('#left_col').load($(this).attr("rel"));
    return false;
});

我真的很感激任何帮助!

更新:

我设法让页面在用户单击返回时更改,但它没有加载正确的状态(它似乎返回两种状态而不是一种),我添加到上述代码的代码是:

window.addEventListener('popstate', function(event) {
    var State = History.getState(); 
    $('#left_col').html(State.data.leftcol);
});
4

2 回答 2

10

事实证明,我需要使用 History.js 更新 statechange 页面,而不是我想的 poState。以下是我为可能遇到相同问题的任何人提供的完整(和工作)代码:

    var History = window.History;
    var origTitle = document.title;

    if ( !History.enabled ) { return false; }
    History.pushState({state:$(this).attr('data-state'),leftcol:$('#left_col').html()}, origTitle, $(this).attr("href"));           // save initial state to browser history

    function updateContent(data) {
        if(data == null) return;                    // check if null (can be triggered by Chrome on page load)
        $('#left_col').html(data);              // replace left col with new (or old from history) data
        History.pushState({state:$(this).attr('data-state'),leftcol:$('#left_col').html()}, origTitle, $(this).attr("href"));           // save this state to browser history
    }

    History.Adapter.bind(window,'statechange',function(){           // use this NOT popstate (history.JS)
        var State = History.getState();
        //History.log(State.data, State.title, State.url);
        updateContent(State.data.leftcol);                                          // call update content with data for left col from saved state
    });

    $('.ajaxload').live("click", function() {                                   // attach click event, get html and send it to updateContent
        $.get($(this).attr("rel"), updateContent);
        return false;
    });
于 2012-06-25T21:54:44.390 回答
0

当您说在状态更改时需要重新加载数据时,您是正确的,因为您必须让 javascript 撤消所做的更改或从原始状态再次呈现内容。

这可能更适合您的议程: https ://github.com/thorsteinsson/jquery-routes

编辑:

您也可以考虑使用backbone.js (http://backbonejs.org/),因为它可以帮助您以一种更容易理解需要做什么的方式创建结构和抽象代码。

Backbone 带有它自己的 url 路由器和所谓的视图。

于 2012-06-21T20:50:57.827 回答