如何检测javascript单击的后退按钮或前进按钮?

cur*_*Boy 6 javascript back-button

只是为了确保,我不是在问如何捕捉后退/前进按钮事件。

window.addEventListener('popstate', function (e) {
                       alert("Yahoooo!!!!"); 
                   });
Run Code Online (Sandbox Code Playgroud)

上面的那个函数是浏览器的后退按钮还是浏览器的前进按钮触发的,但我无法检测到点击了哪个?是后退键还是前进键?

是否有任何特定事件让我可以检测到它是“后退”或“前进”按钮?

编辑:虽然我很欣赏的“重复问题”的建议,在类似的问题张贴在这里的计算器,但接受的答案是从2012年1月!从那时起,很多事情都发生了变化。也许已经有更简单的方法了!

谢谢

小智 1

我遇到了同样的问题,我使用现代 javascript 找到了答案。

该代码可在 GitHub 上找到

您可以使用以下命令检测在任何依赖 popstate/pushstate 的 js 应用程序中按下的浏览器后退和前进按钮:

// e.detail.direction will be the "backward" or "forward" String according the pressed button 
window.addEventListener('nav::user_asked_history', function(e) {
    console.log('nav::direction=', e.detail.direction); 
})
Run Code Online (Sandbox Code Playgroud)

您可以使用以下方法显示/隐藏您自己的应用内后退和前进按钮:

is_nav_forward_possible()
is_nav_backward_possible()
Run Code Online (Sandbox Code Playgroud)

您还可以使用以下方式浏览应用内用户历史记录

let nav_position;
let nav_history; 
Run Code Online (Sandbox Code Playgroud)

享受现代 JS 的乐趣!