JS事件處理

鼠標事件

document.onclick = function(ev) {
  var oEvent = ev || event; //ie下ev不存在,firefox默認傳一個ev
  oEvent.clientX; //鼠標點擊時的位置
}

事件冒泡

//取消事件冒泡
oBtn.onclick = function(ev) {
  var oEvent = ev || event;
  oEvent.cancelBubble = true;
}

控件隨著鼠標移動

document.onmousemove = function(ev) {
  var oEvent = ev || event;
  //clientX和clientY代表的是可視區的坐標
  //所有使用clientX和clientY的都需要計算到滾動條
  //oDiv需要設置style為absolute
  var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
  oDiv.style.top = oEvent.clientY + document.documentElement.scrollTop;
}

按鍵事件

基礎

onkeydown、onkeyup、onkeypress

document.onkeydown = function(ev) {
  oEvent = ev || event;
  oEvent.keyCode
}

小知識

oDiv.offsetLeft; //就是style中的left值 + margin-left值

ctrl+enter留言

oText.onKeydown = function(ev) {
  var oEvent = ev || event;
  //shiftKey,altKey
  if(oEvent.ctrlKey && oEvent.keyCode == 13) {

  }
}

默認行為

屏蔽右鍵菜單

document.oncontextmenu = function(){
  return false;
}

阻止表單提交

oForm.onsubmit = function() {
  return false;
}

自定義右鍵菜單

<style>
  #menu {
    width: 50px;
    background: #CCC;
    border: 1px solid black;
    position: absolute;
    display: none;
  }
</style>
<ul id="menu">
  <li>登錄</li>
  <li>回到首頁</li>
  <li>注銷</li>
</ul>

//js
document.oncontextmenu = function(ev) {
  var oEvent = ev || event;
  var oUl = document.getElementById("menu");
  oUl.style.display = "block;
  //未加 scrollTop和scrollLeft
  oUl.style.left = oEvent.clientX + 'px';
  oUl.style.top = oEvent.clientY + 'px';
  return false;
}
document.onclick = function () {
  var oUl = document.getElementById("menu");
  oUl.style.display = 'none';
}

拖拽事件

//onmousedown -> onmousemove -> onmouseup
window.onload = function() {
    var oDiv = document.getElementById("div1");
    
    var disX = 0;
    var disY = 0;
    
    oDiv.onmousedown = function(ev) {
      var oEvent = ev || event;
      disX = oEvent.clientX - oDiv.offsetLeft;
      disY = oEvent.clientY - oDiv.offsetTop;
      //防止拖出div范圍
      document.onmousemove = function(ev) {
        var oEvent = ev || event;
        
        oDiv.style.left = oEvent.clientX - disX + 'px';
        oDiv.style.top = oEvent.clientY - disY + 'px';
        
      }
      
      document.onmouseup = function() {
        document.onmousemove = null;
        document.onmouseup = null;
      }
    }
    
   return false; //修正firefox下的bug,空div拖拽bug
  }
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 監聽事件 可以用 v-on 指令監聽 DOM 事件來觸發一些 JavaScript 代碼。 方法事件處理器 許多事...
    angelwgh閱讀 385評論 0 0
  • 事件監聽可以使用 v-on 指令: 通常情況下,我們需要使用一個方法來調用 JavaScript 方法。 v-on...
    誰說我是小小云閱讀 191評論 0 0
  • DOM0級事件處理程序 在標簽內之間增加事件處理屬性 使用該方法有兩個弊端:1、 需要分別為標簽賦予onclick...
    Mescal川閱讀 386評論 0 0
  • 簡單理解事件是用戶或瀏覽器自身執行的某種動作。諸如click、load而事件處理程序則是響應某個事件的函數。諸如o...
    Miss____Du閱讀 841評論 7 6
  • HTTP/0.9 HTTP協議是基于TCP/IP協議的應用層協議,它不涉及數據包的傳輸,只是規定了客戶端和服務器的...
    騎著蝸牛去遛狗閱讀 570評論 0 1