JS中的事件

1、鼠标事件

onclick   ondbclick   onmouseover   onmouseout

2、HTML事件

onload   onunload   onsubmit   onresize  onfocus  onchange   onscroll

3、键盘事件

  1. onkeydown:键盘按下时触发
  2. onkeypress:键盘按下并抬起的瞬间触发
  3. onkeyup:键盘抬起时触发

【注意事项】

  • ① 执行顺序:keydown--keypress--keyup
  • ② keypress只能捕获数字、字母、符号键,不能捕获功能键;
  • ③ 长按时循环执行:keydown--keypress
  • ④ 有keydown,不一定有keyup,当长按时焦点失去时,不再触发keyup.
  • ⑤ keypress区分字母大小写,keydown/keyup不区分大小写

4、事件因子

当触发一个事件时,该事件将向事件所调用的函数中,默认传入一个参数,这个参数就是事件因子,包含了事件的各种详细信息。

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

5、如何确定键盘按键

  • ① 在触发函数中,接收事件因子e
e = e || window.event;
  • ② 可以使用 e.key直接取到按下的按键字符(不推荐)
  • ③ 可以使用keyCode/which/charCode取到按键的ASCII码值:
 var code=e.keyCode || e.which || e.charCode;
  //(兼容各种浏览器的写法)
 document.onkeydown=function(e){
    e = e || window.event;
    var code=e.keyCode || e.which || e.charCode;
    console.log(e);
 }

DOM0事件模型

1.内联模型绑定 (行内绑定)

将函数名直接作为HTML标签中事件属性的属性值

 <button onclick="func()">内联模型绑定</button> 

缺点:不符合w3c中关于内容与行为分离的基本规范

2.脚本模型(动态绑定)

通过在js中选中某个节点,然后给节点添加onclick属性

document.getElementById("btn1").onclick=function(){} 

优点:符合w3c中内容与行为分离的基本规范,实现html与js的分离

        缺点:同一个节点,只能添加一次同类型事件。如果添加多次,最后一个生效。

3.DOM0共有的缺点:

      通过DOM0绑定的事件,一旦绑定,无法取消

DOM2事件模型

1.添加DOM2事件绑定

① IE8之前,使用.attachEvent("onclick",函数);

         ② IE8之后,使用.addEventListener("click",函数,true/false);

              参数三:false(默认)表示事件冒泡,传入true表示事件捕获

         ③ 兼容所有浏览器的处理方式

 var btn = document.getElementById("btn2");
 if(btn.attachEvent) {
       btn.attachEvent("onclick", func1);
     } else {
       btn.addEventListener("click", func1);
 }

2.DOM2的优点:

① 同一个节点,可以使用DOM2绑定多个同类型事件
         ② 使用DOM2绑定的事件,有专门的函数取消

3.DOM2取消事件绑定:

① 使用attachEvent绑定,用detachEvent("onclick",func1);取消

         ② 使用addEventListenner绑定,用removeEventListener("click",func1);取消

 document.getElementById("btn3").onclick=function() {
 if(btn.detachEvent) {
        btn.detachEvent("onclick", func1);
     } else {
        btn.removeEventListener("click", func1);
     }
     alert("取消事件绑定");
 }
 

注意: 如果是DOM2绑定的事件需要取消,则绑定事 时,回掉函数必须是函数名,而不能是匿名函数,因为取消事件时,,取消传入函数名进行绑定

js中的事件流模型

1.事件冒泡:

       当触发一个节点的事件时,会从当前节点开始,依次触发其祖先节点的同类型事件,
直到DOM根节点 。

2.事件捕获
       当触发一个节点的事件时,会从DOM根节点开始,依次触发其祖先节点的同类型事件,
知道当前节点自身 。

3.什么时候事件冒泡?事件捕获?

        ①当使用addEventListener绑定事件,第三个参数设为true时表示事件捕获

        ②除此之外的所有事件均为事件冒泡

4.阻止事件冒泡
        ①IE10之前,使用e.cancelBubble = true;

        ②IE10之后,使用 e.stopPropagation();
 function myParagraphEventHandler(e) {
     e = e || window.event;
     if (e.stopPropagation) {
          e.stopPropagation(); //IE10之后
     } else {
          e.cancelBubble = true; //IE10之前
     }
 }

5.阻止默认事件
         ①IE10之前:e.returnValue = false;
         ②IE10之后:e.stopPropagation();

 function eventHandler(e) {
   e = e || window.event;
   // 防止默认行为
   if (e.preventDefault) {
        e.preventDefault(); //IE10之外
    }else {
       e.returnValue = false; //IE10之前
    }
 }
 

JavaScript中的事件模型的更多相关文章

  1. 说说JavaScript中的事件模型

    1.javascript中为元素添加事件处理程序的方法有以下几种方式,可以为javascript元素添加事件处理程序 (1) 直接将事件处理代码写在html中(2) 定义一个函数,赋值给html元素的 ...

  2. 理解javascript中的事件模型

    javascript中有两种事件模型:DOM0,DOM2.而对于这两种的时间模型,我一直不是非常的清楚,现在通过网上查阅资料终于明白了一些. 一.  DOM0级事件模型 DOM0级事件模型是早期的事件 ...

  3. 深入理解javascript中的事件循环event-loop

    前面的话 本文将详细介绍javascript中的事件循环event-loop 线程 javascript是单线程的语言,也就是说,同一个时间只能做一件事.而这个单线程的特性,与它的用途有关,作为浏览器 ...

  4. javascript 中的事件机制

    1.javascript中的事件. 事件流 javascript中的事件是以一种流的形式存在的. 一个事件会也有多个元素同时响应. 有时候这不是我们想要的效果, 我们只是需要某个特定的元素相应我们的绑 ...

  5. JavaScript中的事件对象

    JavaScript中的事件对象 JavaScript中的事件对象是非常重要的,恐怕是我们在项目中使用的最多的了.在触发DOM上的某个事件时,会产生一个事件对象event,这个对象中包含这所有与事件有 ...

  6. JavaScript 进阶教程一 JavaScript 中的事件流 - 事件冒泡和事件捕获

    先看下面的示例代码: <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>Jav ...

  7. 了解javascript中的事件(二)

    本文目录如下: 零.寒暄 一.事件的分类 二.事件代理 2.1 问题引出 2.2 什么是事件代理 2.3 完整示例 二.事件代理 三.事件代理思想的用处 四.总结 零.寒暄 这篇博客本该出现在两个月以 ...

  8. javascript中onclick事件能调用多个方法吗

    Q: javascript中onclick事件能调用多个方法吗? A: 可以的,方法如下onclick="aa();bb();cc();"每个方法用“;”分号隔开就行了

  9. js实例分析JavaScript中的事件委托和事件绑定

    我们在学习JavaScript中,难免都会去网上查一些资料.也许偶尔就会遇到“事件委托”(也有的称我“事件代理”,这里不评论谁是谁非.以下全部称为“事件委托”),尤其是在查JavaScript的事件处 ...

随机推荐

  1. Java:日期类Date与Calendar

    Timestamp类型与日期类型之间的转化? Timestamp timestamp = Timestamp.valueOf("2017-03-17 07:00:00"); Dat ...

  2. QT 设计师使用样式表添加背景

    QT create中样式表可以用来设置背景图.背景颜色.字体大小格式颜色等 1.添加背景图的话需要先添加资源文件 右击项目文件选择添加新文件,再选择QT资源文件(QT resource file)然后 ...

  3. Docker 基础技术之 Linux namespace 源码分析

    上篇我们从进程 clone 的角度,结合代码简单分析了 Linux 提供的 6 种 namespace,本篇从源码上进一步分析 Linux namespace,让你对 Docker namespace ...

  4. JAVA_将唐诗按照古文样式输出

    1. 如有唐诗: 锄禾日当午 汗滴禾下土 谁知盘中餐 粒粒皆辛苦 要求将这首唐诗按照古文样式输出,输出格式如下: 粒谁汗锄 粒知滴禾 皆盘禾日 辛中下当 苦餐土午 public class Text ...

  5. C#之Winform跨线程访问控件

    C#中禁止跨线程直接访问控件,InvokeRequired是为了解决这个问题而产生的,当一个控件的InvokeRequired属性值为真时,说明有一个创建它以外的线程想访问它.此时它将会在内部调用ne ...

  6. 解决firefox不支持-webkit-line-clamp属性

    转载声明: 请注明本文引用自http://www.cnblogs.com/guolizhi/ css中-webkit-line-clamp这个属性表示超过指定行的文本隐藏并且会在结尾加上...号,用起 ...

  7. opencv2.4.9卸载安装

    1.安装opencv2.4.9过程中遇到的问题. 1.使用 sudo apt-get install libopencv-dev 安装OpenCV 2.4.9 发现版本为2.4.8,故卸载重装. 查看 ...

  8. bootStrap Table 如何使用

    最近在使用bootStrap Table 的表格功能有一些自己的理解写下来分享一下主要用的是一个bootStrapTable 和 jquery 的混合开发 具体怎样引入bootStrap Table ...

  9. [HAOI 2006]旅行comf

    Description 题库链接 给你一个 \(n\) 个点, \(m\) 条边的无向图.并给出一个点对 \((s,t)\) ,求 \(s,t\) 间的一条路径,使得路径上最大边和最小边的比值最小. ...

  10. ●BZOJ 1444 [Jsoi2009]有趣的游戏

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1444题解.1: 概率dp,矩阵乘法,快速幂. 对所有串建立AC自动机, 那么如果在trie树 ...