dom事件与event对象总结
1 事件:就是文档或浏览器窗口中发生的一些特定的交互瞬间。
tips:js和xhtml的交互是通过当用户或浏览器操作网页时发生的事件来处理的。
1.1 事件流:即事件的顺序。
事件冒泡:事件从事件发生的目标最内部开始触发,向上触发到最外部(document对象)。
事件捕获:事件捕获正好与冒泡相反。它的事件触发顺序是从最外层的对象(document对象)到最里层的对象。
DOM事件流:dom同时支持事件捕获和事件冒泡,但事件捕获先发生。
1.2 事件处理程序/监听器
定义:为响应一个事件而被调用的函数称为事件处理程序(DOM中叫事件监听器)。
两种指派方式:1.传统事件处理程序指派方法。(DOM0) 2.现代事件处理程序指派方法。
1.传统事件处理程序指派方法。(DOM0):为一个事件指派一个事件处理程序。
1)在js中指定事件处理程序。
eg:
var odiv = document.getElementById("div1");
odiv.onclick = function(){
alert("我被点击了"); //事件处理程序的名称必须全部小写。
}
tips:1.事件处理程序的名称必须全部小写。
2.在绑定事件处理程序到事件属性时,只能引用函数的名称,后面不能加括号。若加括号则表示立即执行函数。
3.不管函数是如何定义的,必须确保在XHTML元素被添加到DOM之前。登记事件处理程序。即js写到后面,保证节点已经加载定义了。
2.现代事件处理程序指派方法。:为一个事件指派多个事件处理程序。 //有兼容性问题。
1)IE浏览器
attachEvent()用于将一个事件处理程序绑定到一个事件。
detachEvent()用于解除事件处理程序的绑定。
[object].attachEvent(“事件处理程序的名称”,函数)
[object].detachEvent(“事件处理程序的名称”,函数)
2)DOM //即是DOM2
DOM中使用addEventListener()和removeEvenList() 方法完成事件处理程序指派和删除的任务。
有三个参数 事件的名称,要指派的函数 ,是否处理程序要用在冒泡或捕获阶段。
第三个参数为true,用在捕获阶段,是则false用在冒泡阶段。
[object].addEventListener(“事件名称”,函数名,bCapture)
[object].removeEvenList()(“事件名称”,函数名,bCapture)
****(重要)兼容性问题的解决:
if(document.addEventListener){ //DOM
odiv.addEventListener("click",fnclick1,true);
}
else if(document.attachEvent){ //IE
odiv.attachEvent("onclick",fnclick1)
}
2 Event对象
tips:Event 对象代表事件的状态。
比如事件在其中发生的元素、键盘按键的状态、鼠标的位置、鼠标按钮的状态。
事件通常与函数结合使用,函数不会在事件发生前被执行!
2.1 定位:
1.ie中:event对象是window对象的一个属性。
必须如下执行:
odiv.onclick = function(){
var oevent =window.event;
}
2.DOM中:event对象只能作为仅有的参数传给事件处理程序。
必须如下执行:
odiv.onclick = function (oEvent){};
2.2 属性和方法
1)ie中event属性和方法:
2)dom中event属性和方法:
3 事件类型:
1.鼠标事件:click dbclick mousedown mouseout mouseover mouseup mousemove
2.键盘事件:keydown keypress keyup
3.HTML事件:load unload change scroll focus blur
dom事件与event对象总结的更多相关文章
- Javascript防冒泡事件与Event对象
防冒泡 防冒泡用到的就是event的属性和方法 function add2shop(e) { if (!e) var e = window.event; e.cancelBubble = true; ...
- javascript事件与event对象的属性
javascript事件列表解说 事件 浏览器支持 解说 一般事件 onclick IE3.N2 鼠标点击时触发此事件 ondblclick IE4.N4 鼠标双击时触发此事件 onmousedown ...
- 事件的event对象基本解释
事件流: 描述的是在页面中接受事件的顺序主要分为两种: 事件冒泡.事件捕获 事件event对象:1. type 获取事件类型2. target获取事件目标3. stopPropagation() 阻止 ...
- 添加事件及Event对象的兼容写法
一.事件流 事件流描述的是从页面中接受事件的顺序. IE的事件流是事件冒泡流,而Netscape的事件流是事件捕获流 1.事件冒泡 事件冒泡,即事件最开始由最具体的元素(文档中嵌套层次最深的那个节点) ...
- DOM 事件深入浅出(二)
在DOM事件深入浅出(一)中,我主要给大家讲解了不同DOM级别下的事件处理程序,同时介绍了事件冒泡和捕获的触发原理和方法.本文将继续介绍DOM事件中的知识点,主要侧重于DOM事件中Event对象的属性 ...
- DOM 事件深入浅出(一)
在项目开发时,我们时常需要考虑用户在使用产品时产生的各种各样的交互事件,比如鼠标点击事件.敲击键盘事件等.这样的事件行为都是前端DOM事件的组成部分,不同的DOM事件会有不同的触发条件和触发效果.本文 ...
- DOM事件对象
触发DOM上的事件时会产生一个事件对象event. event的内容:与事件有关的信息,导致事件的元素,事件的类型及其他与特定事件相关的信息. event对象会传入到事件处理程序中. 一.DOM 中的 ...
- JS事件流、DOM事件流、IE事件处理、跨浏览器事件处理、事件对象与类型
事件的移除 removeEventListener() 第二个参数需要指定要移除的事件句柄,不能是匿名函数,因为无法识别 想要移除成功,那么三个参数必须跟addEventListener中的三个完全一 ...
- 深入理解DOM事件机制系列第四篇——事件模拟
× 目录 [1]引入 [2]模拟机制 [3]自定义事件 前面的话 事件是网页中某个特别的瞬间,经常由用户操作或通过其他浏览器功能来触发.但实际上,也可以使用javascript在任意时刻来触发特定的事 ...
随机推荐
- 佛洛依德 c++ 最短路径算法
//20142880 唐炳辉 石家庄铁道大学 #include<iostream> #include<string> using namespace std; #define ...
- 解迷宫的C++的未完善编程代码........请大神们帮忙改善下.........
这...................................................................... 我也是醉了 看不太懂,大神们求解............ ...
- 美国 ZIP Code 一览表
今天给大家提供美国的Zip Code的原因是大家在注册国外的账号时,需要提供这个Zip Code,因为一般美国的服务默认是面向美国的,甚至是仅支持美国. 以下提供一些美国的zip code 列表. 邮 ...
- 记SpannableString设多少span时注意事项
public void setSpan(Object what, int start, int end, int flags) { } 这个方法里的第一个参数,也就是一些span的对象,不能重复使用. ...
- SpringBoot Schedule 配置
1. 定时任务实现方式 定时任务实现方式: Java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务.使用这种方式可以让你的程序按照某一个频度执行 ...
- Openstack+Kubernetes+Docker微服务实践之路--服务发布
结合上文,我们的服务已经可以正常运行了,但它的访问方式只能通过服务器IP加上端口来访问,如何通过域名的方式来访问到我们服务,本来想使用Kubernetes的Ingress来做,折腾一天感觉比较麻烦,I ...
- Java - 安全的退出线程
stop() 存在的问题 使用 stop() 来退出线程是不安全的.它会解除由线程获取的所有锁,可能导致数据不一致. 举个例子: public class StopTest { public stat ...
- My Sql 中要Alter Table的同学请注意!!!
首先我建议你在对MySQL表做DDL操作时: 1 执行 show processlist 查看,要操作的表(数据库对象)是否处于锁状态 if("未锁定") { 执行DDL语句 }e ...
- 用CSS3和Canvas来画网格
我们经常使用一些excel表格来处理数据,在html中,我们可以用table来制成表格.今天来看一下一些不同的方法. 方法一:使用CSS3的background的linear-gradient属性 l ...
- Node 编程规范
空格, 2个, 因为有多层函数嵌套 行宽, 80个字符 语句分隔, 一律用; 并且占一行 变量定义, 每一个都要用 var, 并且不要定义全局变量 变量名和属性名, 小驼峰, yourName 函数, ...