编程语言
首页 > 编程语言> > javascript – 骨干和历史推送状态

javascript – 骨干和历史推送状态

作者:互联网

使用骨干,是否可以在历史记录中存储一些数据,以便在调用后退时可以重新获取?

在无骨干应用程序中,我的应用程序将类似于以下内容.执行操作时:

//When doing some action
history.pushState(mycurrentData, title, href)

以及以下情况,以便在返回时恢复当前数据:

function popState(event) {  
    if (event.state) { 
        state = event.state;
        //get my data from state
    }
}
window.onpopstate = popState;

我需要在我的骨干应用程序上应用相同的行为.

谢谢

解决方法:

此时,Backbone不可能直接使用

http://backbonejs.org/docs/backbone.html#section-139

您可以在代码中看到几行:

window.history [options.replace? ‘replaceState’:’pushState’]({},document.title,frag);

因此,它始终将数据设置为空对象.

为了使这项工作成为可能,您必须自己存储数据,并在路由触发时使用其他一些检索数据的方法.

就个人而言,我认为修补Backbone以允许数据存储在历史上是值得的.但这是Backbone问题列表的一个想法:)

编辑

看起来其他人想要做到这一点并被击落:https://github.com/documentcloud/backbone/pull/660

标签:backbone-routing,javascript,backbone-js,browser-history
来源: https://codeday.me/bug/20190826/1729217.html