重写url
HTML5新接口,可以改变网址而不刷新页面
仅改变网址,网页不会真的跳转,也不会获取到新的内容,本质上网页还停留在原页面
1、window.history.pushState(data, title, targetURL)
@状态对象:传给目标路由的信息,可为空
@页面标题:目前所有浏览器都不支持,填空字符串即可
@可选url:目标url,不会检查url是否存在,且不能跨域。如不传该项,即给当前url添加data
2、window.history.replaceState(data, title, targetURL)
- @类似于pushState,但是会直接替换掉当前url,而不会在history中留下记录
3、替换url使用:
window.history.replaceState(
null,
null,
window.location.hash.split('?')[0] + '?activeName=' + val.name
)
4、页面初始化判断,应用:
if (this.$route.query && this.$route.query.activeName) {
this.activeName = this.$route.query.activeName
}
本文介绍了HTML5中的两个历史API——pushState和replaceState,这两个方法允许开发者在不刷新页面的情况下更改URL。pushState会将新的URL添加到浏览历史,而replaceState则会直接替换当前URL,且两者都不会触发页面加载。通过示例代码展示了如何使用这些API更新URL参数,并在页面初始化时根据URL参数进行处理。
411

被折叠的 条评论
为什么被折叠?



