【发布时间】:2014-01-23 02:35:36
【问题描述】:
到目前为止,我只知道如果我想在不重新加载整个页面的情况下更改 URL,我必须使用 HTML 浏览器 history API。
我在我的网站中使用了这个概念。让我们举个例子。假设用户在这个页面上
https://www.example.com/aboutus
然后他转到我们有过滤器的产品列表。单击任何过滤器系统会生成类似这样的新网址
https://www.example.com/products?brands[]=song&brands[]=samsung&condition[]=new
内部只是调用
history.pushState({}, 'Title', link.href);
但是,它有一个问题。单击back 按钮会转到上一个过滤器。 我不想要这个功能。我想要,在单击浏览器后退按钮时,它应该转到current 页面之前的页面。在我们的例子中,它应该采取
https://www.example.com/aboutus
谢谢。
【问题讨论】:
-
好吧,如果您要重定向到不同的页面(
/products来自/aboutus,它不会重新加载吗?历史 API 的重点是允许后退菜单中的 url在同一页面上转到以前的状态 -
你也可以使用
-
仅供参考,这个问题是在 coursera 有这个功能时被问到的,目前我怀疑。
标签: javascript html browser-history