如何覆盖*仅*左键单击锚点?

How to override *only* left click on anchor?

我知道我可以使用 event.preventDefault() 来阻止 link 被关注。但我只想阻止普通左键单击或触摸点击的默认操作。 shift-left-click、ctrl-left-click、right click 和 middle click 都应该执行默认操作。

如何检测普通的左键单击或轻触?

您可以勾选 MouseEvent properties like button, altKey, shiftKey & ctrlKey 来执行此操作

document.getElementById('test').addEventListener('click', function(event) {
  snippet.log('button: ' + event.button);
  snippet.log('ctrlKey: ' + event.ctrlKey);
  snippet.log('shiftKey : ' + event.shiftKey);
  snippet.log('altKey : ' + event.altKey);

  if (event.button == 0 && !event.ctrlKey && !event.shiftKey && !event.altKey) {
    event.preventDefault();
  }
})
<!-- Provides the `snippet` object, see http://meta.stackexchange.com/a/242144/134069 -->
<script src="http://tjcrowder.github.io/simple-snippets-console/snippet.js"></script>
<a id="test" href="http://whosebug.com/">test</a>