JS事件對象

概念

當(dāng)某個對象觸發(fā)了某種事件時,所發(fā)生的一切詳細信息保存在一個臨時的地方,這個地方叫做事件對象(黑匣子)

獲取事件對象

要考慮兼容
標準瀏覽器:通過事件觸發(fā)函數(shù)的第一個形參獲得
arguments:偽數(shù)組,接收函數(shù)調(diào)用時所傳遞的所有實參
IE9以下:通過內(nèi)置的全局對象window.event獲得

兼容:
oDiv.onclick = function(event){
var e = event || window.event;
};

使用事件對象

獲取鼠標按鍵的編碼
event.button
oDiv.onmousedown = function(event){
    //var e = event || window.event;
    //console.log(e.button);

    console.log(getButton(event));
};
//兼容
function getButton(event){
    var e = event || window.event;
    if(e){
        return e.button;
    } else if(window.event) {
        switch(e.button){//  IE左中右鍵值為 1 4 2
            case 1:return 0;
            case 4:return 1;
            case 2:return 2;
        }
    }
}
獲取鼠標坐標值

可視區(qū)坐標值
event.clientX, event.clientY
相對坐標值
event.offsetX, event.offsetY
絕對坐標值(頁面坐標值)
event.pageX, event.pageY
屏幕坐標值
event.screenX, event.screenY

獲取鍵盤的編碼
onkeydown/onkeyup  //監(jiān)聽整個鍵盤
    event.keyCode  //字母的大寫的值
onkeypress
    event.keyCode //火狐返回0,google和IE可區(qū)分字母大小寫
    event.charCode, event.which//火狐,google可區(qū)分大小寫,IE不識別
兼容
oDiv.onkeypress = function(event){
    var e = event || window.event;
    var keyValue = e.keyCode || e.charCode || e.which;
    return keyValue;
}

組合鍵(表示按住這些鍵的同時)
event.ctrlKey, event.shiftKey, event.altKey
demo:

document.onclick = function(event){
  event = event || window.event;
  if(event.ctrlKey){
    alert("hello");//按住 ctrl 的時候點擊鼠標  
  }
};
document.onkeydown = function(event){
  event = event || window.event;
  var key = event.keyCode || event.charCode || event.which;
  if(event.shiftKey && event.key == 13){
    alert("你同時按下了shift 和 enter(回車)");
  }
};

事件流(系統(tǒng)默認采用事件冒泡)

事件捕獲(IE,opera不支持)

由祖先節(jié)點依次向他的子節(jié)點依次傳遞事件的過程

事件冒泡

由子節(jié)點一次向他的祖先節(jié)點傳遞事件的過程,成為事件冒泡,如果那個祖先節(jié)點有事件觸發(fā)函數(shù),則執(zhí)行該函數(shù)。具體表現(xiàn)為,我在一個子元素上添加了一個點擊事件,他的所有父級元素上也都添加了點擊事件,當(dāng)我點擊這個子元素的時候,程序會依次從子元素逐級向上調(diào)用點擊事件。下面的 demo 里會依次彈出:btn , box , body

阻止事件冒泡

e.stopPropagation();//只有標準能用
e.cancelBubble = true;//都能用
demo:

<div id="box">
    <input id="btn" type="button" >
</div>
<script type="text/javascript">
    /*
    事件冒泡
    清除事件冒泡:
    e.stopPropagation();IE不能用
    e.cancelBubble();都能用,但還是要做兼容(滑稽~)
    e.cancelBubble?e.cancelBubble = true : e.stopPropagation();
     */
    var btn = document.getElementById("btn");
    var box = document.getElementById("box");
    btn.onclick = function(event){

        var e = event || window.event;
        //e.cancelBubble = true;
        //e.stopPropagation();
        e.cancelBubble?e.cancelBubble = true : e.stopPropagation();
            alert("btn");
        };
        box.onclick = function(){
            alert("box");
        };
        document.body.onclick = function(){
            alert("body");
    };

</script>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 事件對象 在觸發(fā)DOM上的某個事件時,會產(chǎn)生一個事件對象event,這個對象中包含著所有與事件有關(guān)的信息。包括導(dǎo)致...
    落花的季節(jié)閱讀 250評論 0 1
  • 在觸發(fā)DOM上的某個事件時,會產(chǎn)生一個事件對象event。這個對象中包含著所有與事件有關(guān)的信息。包括導(dǎo)致事件的元素...
    Miss____Du閱讀 5,179評論 0 7
  • (續(xù)jQuery基礎(chǔ)(1)) 第5章 DOM節(jié)點的復(fù)制與替換 (1)DOM拷貝clone() 克隆節(jié)點是DOM的常...
    凜0_0閱讀 1,530評論 0 8
  • 在觸發(fā)DOM上的某個事件時,會產(chǎn)生一個事件對象event,這個對象中包含著所有與事件有關(guān)的信息。 DOM中的事件對...
    FeRookie閱讀 348評論 0 3
  • 作為一名軍人妻,有人說這是一種隱形單親。嘗試著和軍人去溝通,說說內(nèi)心感受,可是幾個輪回下來,手機發(fā)燙,對方卻沒有任...
    涅般木閱讀 311評論 3 3

友情鏈接更多精彩內(nèi)容