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
  }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 监听事件 可以用 v-on 指令监听 DOM 事件来触发一些 JavaScript 代码。 方法事件处理器 许多事...
    angelwgh阅读 2,875评论 0 0
  • 事件监听可以使用 v-on 指令: 通常情况下,我们需要使用一个方法来调用 JavaScript 方法。 v-on...
    谁说我是小小云阅读 1,463评论 0 0
  • DOM0级事件处理程序 在标签内之间增加事件处理属性 使用该方法有两个弊端:1、 需要分别为标签赋予onclick...
    Mescal川阅读 2,948评论 0 0
  • 简单理解事件是用户或浏览器自身执行的某种动作。诸如click、load而事件处理程序则是响应某个事件的函数。诸如o...
    Miss____Du阅读 4,447评论 7 6
  • HTTP/0.9 HTTP协议是基于TCP/IP协议的应用层协议,它不涉及数据包的传输,只是规定了客户端和服务器的...
    骑着蜗牛去遛狗阅读 3,567评论 0 1

友情链接更多精彩内容