• 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记录

  • 相关阅读:
    环形二维数组
    梦断代码(三)
    梦断代码(二)
    梦断代码(一)
    CNblogs用户体验
    《软件工程》--读书笔记三
    《软件工程》--读书笔记二
    《软件工程》--读书笔记一
    找出水王
    典型用户
  • 原文地址:https://www.cnblogs.com/lhs-fight/p/14219924.html
Copyright © 2020-2023  润新知