一、什么是事件对象(黑匣子)

  (一)事件:

    onclick

    ondblclick

  (二)当绑定对象的事件被触发时,所发生的所有详细信息都会保存在一个地方,这个地方称为事件对象

    

二、如何获取事件对象

  (一)标准浏览器:给事件触发函数传递的第一个参数;

  (二)IE浏览器:全局对象的属性window.event;

  (三)兼容:evt = evt || window.event

        var e = evt ||window.event

三、如何获取鼠标的编码值

  (一)event.button

    标准浏览器:左键:0;滚轮键:1;右键:2

    IE9以下:左键:1;滚轮键:4;右键:2

    兼容:

    function getButton(evt){

      var e = evt || window.event;

      if(evt){

        return e.button;

      }else if(window.event){

        switch(e.button){

          case 1:return 0;

          case 2:return 1;

          case 3:return 2;

        }

      }

    }

四、如何获取鼠标的坐标值

  (一)相对坐标值:event.offsetX  event.offsetY;相对鼠标所在对象上的坐标值

  (二)绝对坐标值(页面坐标值):event.pageX  event.pageY;鼠标到页面的坐标值

  (三)可视区坐标值:event.clientX  event.clientY;鼠标到页面中可视区域的坐标值

  (四)屏幕坐标值:event.screenX  event.screenY;鼠标到电脑屏幕的坐标值

  思考:如何实现鼠标跟随效果

五、什么是事件流,什么是事件冒泡

  (一)事件流:指事件的流向,有三个阶段:事件捕获/事件目标/事件冒泡

  (二)事件捕获:由外而内,由祖先元素向子孙元素一次传递事件的过程

  (三)事件冒泡:由内而外,由子孙元素向祖先元素一次传递事件的过程

  注:浏览器默认开启的是事件冒泡,IE与欧朋浏览器不支持事件捕获

  (四)如何阻止事件冒泡

    1.标准浏览器:event.stopPropagation()

    2.IE:eventcancelBubble = true;

    兼容:event.stopPropagation ? event.stopPropagation() : event.cancelBubble = true;

六、如何获取键盘的编码值

  (一)event.keyCode event.charCode event.which

     onkeydown/onkeyup : 监听是整个键盘.

     event.keyCode : 获取整个键盘的编码值,字母只获取大写的编码值.,

     onkeypress : 监听除功能键外的键盘值

  兼容 : event.keyCode || event.charCode || event.which

    火狐:

     event.keyCode : 0,

     event.charCode : 大小写字母的编码值,

     event.which : 大小写字母的编码值,

    谷歌:

     event.keyCode : 大小写字母的编码值,

     event.charCode : 大小写字母的编码值,

     event.which : 大小写字母的编码值,

七、如何设置组合键(快捷键)

  (一)event.ctrlKey

  (二)event.shiftKey

  (三)event.altKey

JS学习笔记Day11的更多相关文章

  1. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

  2. Vue.js学习笔记(2)vue-router

    vue中vue-router的使用:

  3. JS 学习笔记--9---变量-作用域-内存相关

    JS 中变量和其它语言中变量最大的区别就是,JS 是松散型语言,决定了它只是在某一个特定时间保存某一特定的值的一个名字而已.由于在定义变量的时候不需要显示规定必须保存某种类型的值,故变量的值以及保存的 ...

  4. WebGL three.js学习笔记 使用粒子系统模拟时空隧道(虫洞)

    WebGL three.js学习笔记 使用粒子系统模拟时空隧道 本例的运行结果如图: 时空隧道demo演示 Demo地址:https://nsytsqdtn.github.io/demo/sprite ...

  5. WebGL three.js学习笔记 法向量网格材质MeshNormalMaterial的介绍和创建360度全景天空盒的方法

    WebGL学习----Three.js学习笔记(5) 点击查看demo演示 Demo地址:https://nsytsqdtn.github.io/demo/360/360 简单网格材质 MeshNor ...

  6. WebGL three.js学习笔记 创建three.js代码的基本框架

    WebGL学习----Three.js学习笔记(1) webgl介绍 WebGL是一种3D绘图协议,它把JavaScript和OpenGL ES 2.0结合在一起,通过增加OpenGL ES 2.0的 ...

  7. vue.js 学习笔记3——TypeScript

    目录 vue.js 学习笔记3--TypeScript 工具 基础类型 数组 元组 枚举 字面量 接口 类类型 类类型要素 函数 函数参数 this对象和类型 重载 迭代器 Symbol.iterat ...

  8. 2019-4-29 js学习笔记

    js学习笔记一:js数据类型   1:基本数据类型       number类型(整数,小数)      String类型          boolean类型        NaN类型其实是一个nu ...

  9. 一点感悟:《Node.js学习笔记》star数突破1000+

    写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...

随机推荐

  1. C#开发WEBService服务 C++开发客户端调用WEBService服务

    编写WEBService服务端应用程序并部署 http://blog.csdn.net/u011835515/article/details/47615425 编写调用WEBService的C++客户 ...

  2. jquery datatable 实例操作

    var dataTables = $(".table").dataTable({ data: d,//为ajax的值,没有直接用插件自带的请求数据方式,个人觉得data的方式好控制 ...

  3. Github上如何查看当前最流行的开源项目

    先声明下:只针对初学者,大神的话勿喷. 针对题标的这个问题,按照如下步骤操作即可: 进入Github网站后,显示的页面如下所示: 点击"Explore"链接,进入如下页面: 页面上 ...

  4. Disruptor-架构思维的转变

    相对于无锁技术,Disruptor对于架构思维的转变,才是其最大亮点. Pub Event 说到RingBuffer做的队列,通常都说的是“一读一写“,或者“多读一写“.而Disruptor天生是为“ ...

  5. echarts堆叠图添加总量

    echarts在使用中往往会遇到需要展示总量信息的情况,比较典型的就是3维统计的堆叠柱状图 堆叠是在柱状图的基础上,给几项设置同一stack来实现的.不考虑在tips中实现总和,有两种方式可以实现总和 ...

  6. R语言学习——向量

    以下为在RStudio中输入 #为注释符,其后内容程序不执行 > #向量是用于储存数值型.字符型或者逻辑型数据的一维数组.执行组合功能的函数c()可用来创建向量.示例如下: > a< ...

  7. ESP8266远程OTA升级

    https://blog.csdn.net/xh870189248/article/details/80095139 https://www.wandianshenme.com/play/arduin ...

  8. SQL瓶颈分析,以及适应最佳执行计划的探讨

    原文地址:   https://blog.csdn.net/daiqiulong2/article/details/86546446?tdsourcetag=s_pcqq_aiomsg 年纪大了,慢慢 ...

  9. Spring Boot:The field file exceeds its maximum permitted size of 1048576 bytes

    错误信息:The field file exceeds its maximum permitted size of 1048576 bytes原因是因为SpringBoot内嵌tomcat默认所能上传 ...

  10. .NET 开源项目 Anet 介绍

    使用 Anet 有一段时间了,已经在我的个人网站(如 bookist.cc)投入使用,目前没有发现什么大问题,所以才敢写篇文章向大家介绍. GitHub 地址:https://github.com/a ...