3

我试图在某些情况下覆盖默认的返回行为,并更新我的应用程序状态而不是触发历史 popstate 事件。

是否有其他事件我应该加入以防止默认行为?我发现远程后退按钮使用 e.keyCode === 27 触发 keydown 事件

const FIRE_REMOTE_BACK = 27;
handleBackButton = (e) => {
  e.stopImmediatePropagation();
  e.stopPropagation();
  e.preventDefault();
  // update app state
}
handleKeyDown = (e) => {
  const {keyCode} = e;
  
  if (keyCode === FIRE_REMOTE_BACK) {
    return handleBackButton(e);
  }
}

我看到我的应用程序状态短暂更新,但随后返回事件完成。

4

2 回答 2

3

回答了我自己的问题。监听'keyup'(不是keydown)事件和preventDefault()

于 2016-10-06T00:43:37.243 回答
1

就我而言(FireOS 7 WebView Chrome 88),我还必须添加以下内容:

document.addEventListener('keypress', function (event) {
  event.stopPropagation();
  event.preventDefault();
});

否则我会让远程键交互双重触发。

于 2021-05-28T13:41:59.260 回答