history

window.location.hash = 'contDEF';

window.onhashchange=function(e){a=e;alert(1)}

使用 history.back(), history.forward()和 history.go() 方法来完成在用户历史记录中向后和向前的跳转.等操作会主动触发popstate 事件

window上有popstate事件

pushState,replaceState 不会触发popstate事件

pushState只会在当前history中添加一条记录,并不会刷新浏览器

replaceState会替换当前的history中的记录,并且刷新浏览器

window.addEventListener('popstate',function(){alert(11)})

从某种程度来说, 调用 pushState() 和 window.location = "#foo"基本上一样, 他们都会在当前的document中创建和激活一个新的历史记录。但是 pushState() 有以下优势:

  • 新的URL可以是任何和当前URL同源的URL。但是设置 window.location 只会在你只设置锚的时候才会使当前的URL。

  • 非强制修改URL。相反,设置 window.location = "#foo"; 仅仅会在锚的值不是#foo情况下创建一条新的历史记录。

  • 可以在新的历史记录中关联任何数据。window.location = "#foo"形式的操作,你只可以将所需数据写入锚的字符串中。

注意: pushState() 不会造成 hashchange 事件调用, 即使新的URL和之前的URL只是锚的数据不同。window.location改变,会增加history记录

原文地址:https://www.cnblogs.com/lhs-fight/p/14219924.html