当前位置 博文首页 > 文章内容

    H5的pushState和replaceState

    作者: 栏目:未分类 时间:2020-07-20 18:01:33

    本站于2023年9月4日。收到“大连君*****咨询有限公司”通知
    说我们IIS7站长博客,有一篇博文用了他们的图片。
    要求我们给他们一张图片6000元。要不然法院告我们

    为避免不必要的麻烦,IIS7站长博客,全站内容图片下架、并积极应诉
    博文内容全部不再显示,请需要相关资讯的站长朋友到必应搜索。谢谢!

    另祝:版权碰瓷诈骗团伙,早日弃暗投明。

    相关新闻:借版权之名、行诈骗之实,周某因犯诈骗罪被判处有期徒刑十一年六个月

    叹!百花齐放的时代,渐行渐远!



    这两个是H5规范为window.history引用的两个新的api,pushState和replaceState,我们可以使用它很方便达到改变url不重载页面的目的。

    1.pushState

    说明

    浏览器不会向服务端请求数据,直接改变url地址,可以理解为变相版的hash;但是不像hash一样,浏览器还是会记录pushState的历史记录,可以使用浏览器的前进,后退的功能。

    使用方法

    pushState(state,title,url)

    参数说明

    state:state对象,可以存放一些数据表示当前状态,可以通过history.state读取

    title:可选从参数,目前被忽略了,未来可能有用,建议传递一个空的字符串

    url:改变过后的url地址,不允许跨域。

    2.replaceState

    说明

    不同于pushState,replaceState仅仅只是修改了对应的历史记录,不会再history中留下记录,而pushState会在浏览器上创建一条新的历史记录

    假定当前网页是example.com/example.html。

    拓展:popstate事件

    每当同一个文档历史记录(即history对象)发生变化是,就会触发popstate事件。

    注意,仅仅调用pushState()方法或replaceState()方法 ,并不会触发该事件,只有用户点击浏览器倒退按钮和前进按钮,或者使用 JavaScript 调用History.back()、History.forward()、History.go()方法时才会触发。另外,该事件只针对同一个文档,如果浏览历史的切换,导致加载不同的文档,该事件也不会触发

    页面第一次加载的时候,浏览器不会触发popstate事件

     

    请参考:https://blog.csdn.net/yexudengzhidao/article/details/101448168