history对象中replaceState详解

531 阅读1分钟

window.history.replaceState(stateObj, title[, url]);

参数 stateObj

状态对象是一个JavaScript对象,它与传递给 replaceState 方法的历史记录实体相关联.

title

大部分浏览器忽略这个参数, 将来可能有用. 在此处传递空字符串应该可以防止将来对方法的更改。或者,您可以为该状态传递简短标题

url 可选

历史记录实体的URL. 新的URL跟当前的URL必须是同源; 否则 replaceState 抛出一个异常.

window.history两个方法pushState和replaceState详解

无跳转重写url

  • HTML5新接口,可以改变网址而不刷新页面
  • 存在跨域问题,不支持重写到另一个域名下
  • 仅改变网址,网页不会真的跳转,也不会获取到新的内容,本质上网页还停留在原页面

一、window.history.pushState(data, title, targetURL);

  • @状态对象:传给目标路由的信息,可为空
  • @页面标题:目前所有浏览器都不支持,填空字符串即可
  • @可选url:目标url,不会检查url是否存在,且不能跨域。如不传该项,即给当前url添加data

二、window.history.replaceState(data, title, targetURL);

  • @类似于pushState,但是会直接替换掉当前url,而不会在history中留下记录

三、为了让大家更好的理解两者的区别,我以下面链接为例:

1、相同点:都不支持跨域

2、不同点:是否会留下记录