<script>
var bt = document.getElementById("bt");
bt.addEventListener('click',function(e){ alert(e.currentTarget.name); },false);
</script>
瀏覽器常用事件包括:
頁面加載/離開事件
縮放事件
光標事件
鼠標事件
mousedown/mouseenter/mouseleave/mouseover/mouseout/mouseup
拖拽事件
drag/dragend/dragenter/dragleave/dragover/dragstart/drop
滾動事件
單擊/雙擊事件
頁面控件事件
change/select/show/wheel/invalid
表單事件
動畫事件
transitionend/animationstart/animationiteration
鍵盤事件
觸摸屏事件
touchcancel/touchend/touchmove/touchstart
媒體控件事件
volumechange/abort/ended/...
網絡離線/上線事件
快捷菜單事件
事件是個對象,有很多的屬性可以使用,常用的包括:
獲取坐標
clientX/clientY/screenX/screenY/offsetX/offsetY/MovementX/MovementY
獲取鍵盤KEY
獲取事件源
組合鍵
用代碼實現觸發事件:createEvent()
var x = document.createEvent("MouseEvent");
x.initMouseEvent("mouseover", true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
document.getElementById("myDiv").dispatchEvent(x);
自動下載時常用這種方式
var evt = document.createEvent('MouseEvents');
evt.initEvent('click', false, false);
link.dispatchEvent(evt);
refer:https://www.w3schools.com/jsref/dom_obj_event.asp
target/currentTarget/EventTarget
target是真正觸發事件的元素
currentTarget是當前監聽到該事件的元素
EventTarget為可以進行事件監聽的元素的祖先。

refer:https://www.cnblogs.com/oneplace/p/6786193.html
clientX、offsetX、screenX、pageX
offsetX,offsetY 是相對於e.target的上邊框和左邊框的距離。

refer: https://blog.csdn.net/weixin_41342585/article/details/80659736
