我正在编写代码来创建一个类似于从时间线上在Facebook上观看照片的用户体验......
我通过 HTML5历史记录API 完成了大部分工作。这是我点击图片时正在做的事情......
preventDefault()
来避免链接(到图像页面),而是AJAX加载带图像的模态pushState
图片页面的URI,因此它显示在地址栏中问题:在第4步,有没有办法绕过历史API,让浏览器执行标准的“后退”操作,这样我就可以返回上一页(即时间轴) )?
答案 0 :(得分:0)
你有没有尝过一个好的'{1}}?
答案 1 :(得分:0)
我这样做:
第1步 - 保存初始页面网址(尚未更改)
var savedPageStateURL = window.location.pathname;
第2步 - 替换当前的历史记录状态(不推送,仅替换)
window.history.replaceState( {}, null , url );
第3步 - 恢复历史记录更改并返回第一步状态
if( 'pushState' in window.history && window.history.state )
window.history.replaceState( {}, null , savedPageStateURL );