码迷,mamicode.com
首页 > Windows程序 > 详细

历史记录管理(window.history)

时间:2020-05-02 11:33:53      阅读:84      评论:0      收藏:0      [点我收藏+]

标签:range   output   code   ssi   回退   rgb   window   first   clip   

代码在这

<div>
    <input type="range" id="myRange">
    <span id="output"></span>
    <div>
        <progress id="myProgress" max="100"></progress>
    </div>
</div>
function toggle() {
    let value = $(‘#myRange‘).val()
    $(‘#output‘).text(value)
    $(‘#myProgress‘).val(value)
}
toggle()
$(‘#myRange‘).on(‘change‘, function () {
    toggle()
})

技术图片

以上这种不请求页面的情况是没有历史记录的,后退按钮用不了。

H5 API增加的window.history.pushState()window.onpopstate事件window.history.replaceState()可以在这种情况下进行历史记录的管理。

它们管理着一个状态对象栈和对应的URLpushState()可以为栈中添加一个新的状态对象和对应的URL,它们组成了一条记录,可以用这个对象设置页面状态。当点击后退按钮就触发onpopstate事件,该事件回调参数中有event.state保存着pushState添加的上一个状态对象,我们用这个旧的状态对象,就可以让页面恢复到旧的状态中。

replaceState()pushState()差不多,就是不添加新的状态,而是修改掉当前所在记录的状态。
还有个go(n),跟点击后退按钮差不多,就是可以指定后退多少,后退按钮只能一页一页退。

let state,initState
window.onpopstate = popState
window.onload = firstTimeLoad
function firstTimeLoad() {
    state = {
        id:1,
        value: $(‘#myRange‘).val()
    }
    initState = Object.assign({},state)
    $(‘#myRange‘).on(‘change‘,changeAction)
    display(state)
}
function changeAction(){
    state.id++
    state.value = $(this).val()
    save(state)
    display(state)
}
function popState(event){
    if(event.state){
        state = event.state
        display(state)
    }else{
        display(initState)
    }
}
function save(state){
    let url = ‘#history-‘ + state.id
    window.history.pushState(state,‘‘,url)
}
function display(state){
    $(‘#myRange‘).val(state.value)
    $(‘#output‘).text(state.value)
    $(‘#myProgress‘).val(state.value)
}

注意popState(event)方法中的else部分,因为在页面onload时浏览器本身会往栈内添加第一个状态对象,这个对象是null,栈就会这样[null,记录1,记录2...],因此在页面加载firstTimeLoad()方法里记录初始状态,好在回退到为null对象时,用这个初始状态设置页面。

技术图片

本文转载于:历史记录管理(window.history)

历史记录管理(window.history)

标签:range   output   code   ssi   回退   rgb   window   first   clip   

原文地址:https://www.cnblogs.com/baimeishaoxia/p/12817141.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!