我知道我可以event.preventDefault()
用来阻止链接被关注。但是我只想阻止对纯左键单击或轻触的默认操作。shift-左键单击,ctrl-左键单击,右键单击和中键单击均应执行默认操作。
如何检测普通的左键单击或触摸点击?
您可以检查MouseEvent属性,例如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://stackoverflow.com/">test</a>
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句