pushState

一、认识window.history

window.history表示window对象的历史记录,是由用户主动产生,并且接受javascript脚本控制的全局对象。window对象通过history对象提供对览器历史记录的访问能力。它暴露了一些非常有用的方法和属性,让你在历史记录中自由前进和后退。

1、历史记录的前进和后退

在历史记录中后退,可以这么做:

  1. window.history.back();

这就像用户点击浏览器的后退按钮一样。

类似的,你可以前进,就像在浏览器中点击前进按钮,像这样:

window.history.forward();

2、移动到指定历史记录点

通过指定一个相对于当前页面位置的数值,你可以使用go()方法从当前会话的历史记录中加载页面(当前页面位置索引值为0,上一页就是-1,下一页为1)。

要后退一页(相当于调用back()):

  1. window.history.go(-1);

向前移动一页(相当于调用forward()):

  1. window.history.go(1);

类似的,传递参数“2”,你就可以向前移动2个记录点。你可以查看length属性值,了解历史记录栈中一共有多少个记录点:

  1. window.history.length;

二、修改历史记录点

HTML5的新API扩展了window.history,使历史记录点更加开放了。可以存储当前历史记录点、替换当前历史记录点、监听历史记录点,下面逐一简要说明一下。

1、存储当前历史记录点

存储的方式类似于数组的入栈(Array.push()),在window.history里新增一个历史记录点,例如:

  1. //当前的url为:http://www.qingdou.me/index.html
  2. varjson={time:new Date().getTime()};
  3. //@状态对象:记录历史记录点的额外对象,可以为空
  4. //@页面标题:目前所有浏览器都不支持
  5. //@可选的url:浏览器不会检查url是否存在,只改变url,url必须同域,不能跨域
  6. window.history.pushState(json,”",”http://www.qingdou.me/post-1.html”);

    var state = {
            title: title,
            url: options.url,
            otherkey: othervalue
    };
    window.history.pushState(state, document.title, url);
    

执行了pushState方法后,页面的url地址为http://www.qingdou.me/post-1.html。

2、替换当前历史记录点

window.history.replaceState和window.history.pushState类似,不同之处在于replaceState不会在window.history里新增历史记录点,其效果类似于window.location.replace(url),都是不会在历史记录点里新增一个记录点的。当你为了响应用户的某些操作,而要更新当前历史记录条目的状态对象或URL时,使用replaceState()方法会特别合适。

3、监听历史记录点

监听历史记录点,直观的可认为是监听URL的变化,但会忽略URL的hash部分,监听URL的hash部分,HTML5有新的API为onhashchange,我的博客里也有说到该方法和跨浏览器的兼容解决方案。可以通过window.onpopstate来监听url的变化,并且可以获取存储在该历史记录点的状态对象,也就是上文说到的json对象,如:

  1. //当前的url为:http://www.qingdou.me/post-1.html
  2. window.onpopstate=function()
  3. {
  4. //获得存储在该历史记录点的json对象
  5. varjson=window.history.state;
  6. //点击一次回退到:http://www.qingdou.me/index.html
  7. //获得的json为null
  8. //再点击一次前进到:http://www.qingdou.me/post-1.html
  9. //获得json为{time:1369647895656}
  10. }

值得注意的是:javascript脚本执行window.history.pushState和window.history.replaceState不会触发onpopstate事件。

还有一点注意的是,谷歌浏览器和火狐浏览器在页面第一次打开的反应是不同的,谷歌浏览器奇怪的是回触发onpopstate事件,而火狐浏览器则不会。

浏览器兼容性表:

Feature Chrome Firefox (Gecko) Internet Explorer Opera Safari
replaceState, pushState 5 4.0 (2.0) 10 11.50 5.0
history.state 18 4.0 (2.0) 10 11.50 6.0

基于ajax与html无刷新换url的jquery插件pjax。大家可以去网上看看。

### HTML5 `pushState` 不生效的原因及解决方案 `pushState` 是 HTML5 中引入的一个方法,用于在不刷新页面的情况下更改浏览器的 URL,并且可以将新的状态保存到浏览器的历史记录中。如果 `pushState` 方法未按预期工作,可能由以下原因导致: #### 1. 浏览器兼容性问题 `pushState` 是 HTML5 的功能,部分老旧浏览器可能不支持此方法。如果目标用户使用的是不支持 HTML5 的浏览器,则会导致 `pushState` 无法正常工作[^1]。 **解决方案**:检查目标用户的浏览器版本是否支持 `pushState` 方法。可以通过以下代码检测浏览器支持情况: ```javascript if (history.pushState) { console.log("Browser supports pushState"); } else { console.log("Browser does not support pushState"); } ``` #### 2. 脚本错误或逻辑问题 如果在调用 `pushState` 方法时,传入的参数不符合规范,可能会导致方法失效。`pushState` 方法需要三个参数:状态对象、标题(通常为空字符串)和新的 URL。如果这些参数有误,可能会导致问题。 **解决方案**:确保正确调用 `pushState` 方法。例如: ```javascript history.pushState({ page: 1 }, "Title", "/new-url"); ``` 上述代码中,第一个参数是一个状态对象,第二个参数是标题(通常为空字符串),第三个参数是新的 URL。 #### 3. 服务器端配置问题 即使前端代码正确实现了 `pushState`,如果服务器端未正确配置以处理新的 URL 请求,当用户刷新页面时,服务器可能无法找到对应的资源,从而返回 404 错误。这种情况通常发生在单页应用(SPA)中。 **解决方案**:确保服务器端能够正确处理前端路由。例如,在 Nginx 中可以添加以下配置: ```nginx location / { try_files $uri /index.html; } ``` 这会将所有未匹配的请求重定向到 `index.html`,从而允许前端框架接管路由逻辑[^1]。 #### 4. 页面加载完成后调用 `pushState` 如果在页面尚未完全加载时调用了 `pushState`,可能会导致行为异常。因此,建议在页面加载完成后再调用该方法。 **解决方案**:将 `pushState` 调用放在 `DOMContentLoaded` 或 `load` 事件中: ```javascript document.addEventListener("DOMContentLoaded", function() { history.pushState({ page: 1 }, "Title", "/new-url"); }); ``` #### 5. 历史记录限制 浏览器对历史记录的长度有一定限制。如果历史记录条目过多,可能会导致 `pushState` 方法失效。 **解决方案**:定期清理不必要的历史记录,避免历史记录条目过多。可以通过 `replaceState` 方法替换当前历史记录条目,而不是不断增加新条目: ```javascript history.replaceState({ page: 1 }, "Title", "/new-url"); ``` --- ### 示例代码 以下是一个完整的 `pushState` 使用示例: ```javascript // 检查浏览器是否支持 pushState if (history.pushState) { // 调用 pushState 方法 history.pushState({ page: 1 }, "New Title", "/new-page"); // 监听 popstate 事件,处理用户点击后退/前进按钮的行为 window.addEventListener("popstate", function(event) { console.log("Current state:", event.state); }); } else { console.error("pushState is not supported in this browser"); } ``` --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值