javascript中的事件对象和处理


  • 键盘事件的类型相对应的操作 操作keyCode 不同于 操作charCode
  • this代表的上下文
  • 事件动作得到事件发起位置的相对坐标 与元素位置的相对坐标的不同
  • 重要的事情说三遍 IE 的事件对象和 W3C 的事件体系不同,需要时时注意兼容性问题!!注意!!

本节索引

  1. 事件对象 --事件函数
  2. 事件类型 (鼠标事件 + 键盘事件)
  3. event(作为参数传递)的属性和方法
  4. 传统事件的绑定
  5. W3C事件绑定

事件对象

  1. 事件对象:事件对象是事件处理函数通过参数传递的(事件对象可以是隐藏的参数)

     document.onclick = function(){
         alert(arguments[0]);
     }
    
  2. 事件处理函数

     1. 对象.事件处理函数 = function(evevt){}   event是可以隐藏的参数
     
     2. 事件处理函数(监听器) 事件类型 + 事件动作 onclick
     
     3. document.onclick = function(evevt) {}
    
  3. this上下文对象

    this代表当前绑定事件的函数,this有上下文环境

基本事件处理函数 鼠标事件 + 键盘事件 + HTML事件

所有的事件处理函数都会都有两个部分组成,on + 事件名称

  1. 鼠标事件
事件处理函数 影响的元素 发生时间
click 页面所有的元素都可能触发该事件 用户单击对象时触发
dblclick 链接、按钮、表单对象 用户双击主鼠标键
mousedown 链接、按钮、表单对象 当用户按下了鼠标还未弹起时触发
mouseup 链接、按钮、表单对象 当用户释放鼠标按钮时触发
mouseover 链接 当鼠标移到链接时
mouseout 链接 当鼠标移出某个元素上方时触发
mousemove 元素 当鼠标指针在元素上移动时触发
  1. 键盘事件
事件处理函数 影响的元素 发生的时间
keydown 文档、图像、链接、表单 当按键被按下时 如果按住不放,会重复触发
keypress 文档、图像、链接、表单 当用户按下键盘上的字符键触发如果按住不放,会重复触发
keyup 文档、图像、链接、表单 当用户释放键盘上的键触发
  1. HTML事件
事件处理函数 影响的元素 发生的时间
load 主题、框架集、图像 文档或图像加载后
unload 主题、框架集、图像 当页面完全卸载后触发
select 表单元素 当选择一个表单对象时
change 输入框,选择框和文本区域 当改变一个元素的值且失去焦点时
focus 窗口、框架、所有表单对象 当单击鼠标或者将鼠标移动聚焦到窗口或框架时
blur 窗口、框架、所有表单对象 当焦点从对象上移开时
submit 表单 当发送表格到服务器时
reset 表单复位按钮 单击表单的 reset 按钮
resize 窗口 当选择一个表单对象时
scroll 窗体对象 当用户滚动带滚动条的元素时触发
事件类型 (鼠标事件 + 键盘事件)

  1. 鼠标事件

    click 一般只有鼠标左键单击时触发

    mousedown/mouseup 会触发button属性

     button属性的值
     e.button == 0 主鼠标键(左键)
     e.button == 1 鼠标中键
     e.button == 2 次鼠标键 (右键)
    
  2. 可视区域以及屏幕坐标(事件的坐标位置元素的坐标位置不同元素的坐标位置稍后讲解

    event.clientX / event.clientY 表示事件发生位置相对于浏览器的坐标

    event.screen / event.screenY 表示事件相对于屏幕的坐标

  3. 键盘事件 单独的键盘敲击 / 组合键盘敲击(shift/comment/ctrl)

    • 修改键事件属性 得到 boolear 值

        e.shiftKey
        e.ctrlKey
        e.altKey
        e.metaKey    `判断是否按下window / comment键`
      
    • 键盘事件的两种类型的事件 操作键码 / 操作字符编码(ACSII编码)

      1. keydown / keyup 得到键盘的键码keyCode

         document.keyDown = function(e){
             console.log(e.keyCode);
         }
        
      2. keyPress 得到键盘的字符编码charCode

         document.keyPress = function(){
             console.log(e.charCode);
         }
        

      可以使用 String.fromCharCode()将 ASCII 编码转换成实际的字符

    小写字母a 对应的键盘键码 与 字符编码

    键盘事件类型

event对象的事件和方法

事件冒泡 + 事件的默认行为 + 事件目标(target) + 事件的细节属性

  • 事件冒泡

      e.bubbles               boolean     设置是否可以取消事件的冒泡行为
      
      e.stopPropagation()     方法(需要在 e.bubbles = true 时执行)
              阻止事件冒泡行为的方法 
    
  • 事件默认行为

      e.cancelable            boolean     设置是否可以取消事件的默认行为
          
      e.preventDefault()      方法(需要在 e.cancellable = ture 时执行)
              取消是事件的默认行为的方法
    
  • 事件目标 e.target

  • 时间的细节属性

      e.detail            与事件相关的细节属性
          
      e.type              事件类型
          
      e.currentTarget     DOM元素   事件处理函数中当前正在处理的元素
    
  • 事件冒泡的处理

    事件冒泡,是从里往外逐个触发。事件捕获,是从外往里逐个触发。那么现代的浏览器 默认情况下都是冒泡模型

    skitch.png
传统事件绑定 (已经不建议使用)

  1. 传统事件绑定一般应用脚本模型 (讲一个事件处理函数绑定到函数上)

     objectDOM.onclick = function(){
         alert('传统事件绑定');
     }
    
  2. 脚本模型的诸多问题

    • 相同 事件类型名称的 函数会被覆盖 (相同类型名称的事件后面的会将前面的事件覆盖)

    • 事件切换执行时的 this 传值问题

        box.onclick = function () {
            toRed();
            toBlue.call(this);      // 必须将this传递到切换器中
        };
      
        function toRed() {
            this.className = 'red';
            this.onclick = toBlue;
        }
      
        function toBlue() {
            this.className = 'blue';
            this.onclick = toRed;
        }
      
W3C事件处理函数

1. DOM2 事件处理函数中包括 addEventListener() + removeEventListener() 两个方法.
2. 所有的DOM节点中都包括这两个方法。
3. 两个方法都接受三个参数  
    事件名称(标准的事件类型名称),
    处理函数,
    冒泡或者捕获(true 表示捕获,false表示冒泡) 
  1. 事件处理函数

    objectDOM.addEventListener(事件名,处理函数,冒泡或捕获)

    objectDOM.removeEventListener(事件名,处理函数,冒泡或捕获)

  2. W3C事件绑定的特点

    • 不需要自定义函数的切换

    • 可以屏蔽相同得到函数

        window.addEventListener('load',init,flase);    //第一次被执行
        window.addEventListener('load',init,flase);    //第二次被屏蔽
        function init(){
            alert("W3C");
        }
      
    • 可以设置冒泡或者捕获

    • 事件切换器 相当于JQuery中的事件的toggle()的方法

        window.addEventListener('load', function() { 
            var box = document.getElementById('box');
            box.addEventListener('click', function() {
                    alert('Lee');
                }, false);
            box.addEventListener('click', toBlue, false);
        }, false);
      
        function toRed() {
            this.className = 'red';
            // 在执行切换事件之前需要移除原来的同名的事件
            this.removeEventListener('click', toRed, false); 
            this.addEventListener('click', toBlue, false);
        }
      
        function toBlue() {
            this.className = 'blue';
            this.removeEventListener('click', toBlue, false);               this.addEventListener('click', toRed, false);
        }
      
    • 冒泡和捕获

        document.addEventListener('click', function () { 
            alert('document');
        }, true);               //布尔值 true 代表捕获
        
        box.addEventListener('click', function () {
            alert('Lee'); 
        }, flase);              //布尔值为 flase 代表冒泡 
      
  3. W3C的鼠标移动事件

    鼠标移动时间的获取 mouseover/mouserout

    • e.target 用于获取当前正在操作的事件的对象

    • W3C 提供了一个属性:relatedTarget 用于获取从哪里移入和从哪里移出的 DOM 对象

        objectDOM.ommouseover = function(e) {
                e.relatedTarget     //获取移入该DOM对象的上一个DOM对象
        }
        
        objectDOM.onmouserout = function(e){
            e.relatedTarget     //用于获取移出 该 DOM 对象的下一个 DOM对象
        }
      
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,245评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,749评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,960评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,575评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,668评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,670评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,664评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,422评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,864评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,178评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,340评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,015评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,646评论 3 323
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,265评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,494评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,261评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,206评论 2 352

推荐阅读更多精彩内容

  • 以下文章为转载,对理解JavaScript中的事件处理机制很有帮助,浅显易懂,特分享于此。 什么是事件? 事件(E...
    jxyjxy阅读 3,035评论 1 10
  • 声明:本文来源于http://www.webzsky.com/?p=731我只是在这里作为自己的学习笔记整理一下(...
    angryyan阅读 6,998评论 1 6
  • 什么是事件: 我们可以简单的把事件理解为浏览器的感知系统。比如说:他可以感觉到用户是否点击(click)了页面、鼠...
    张松1366阅读 6,788评论 1 6
  • 我爱电影 2014年11月7日 22:10 最近卷起一股电影热潮,特别想追忆以前的电影,无论国内外,经典的,永远不...
    小鹿风阅读 152评论 0 0
  • 大四刚刚开学,收到了洗发水的快递短信。没细看,带着手机就去了申通点。到了之后跟以往取快递一样:给编码、念姓名、对手...
    芋头_bfc6阅读 155评论 0 0